Printemps - Cycle de vie du haricot

Le cycle de vie d'un haricot printanier est facile à comprendre. Lorsqu'un bean est instancié, il peut être nécessaire d'effectuer une initialisation pour le mettre dans un état utilisable. De même, lorsque le haricot n'est plus nécessaire et est retiré du conteneur, un certain nettoyage peut être nécessaire.

Bien qu'il existe des listes d'activités qui se déroulent dans les coulisses entre le moment de l'instanciation du haricot et sa destruction, ce chapitre ne traitera que de deux méthodes importantes de rappel du cycle de vie du haricot, qui sont requises au moment de l'initialisation du haricot et de sa destruction.

Pour définir la configuration et le démontage d'un bean, nous déclarons simplement le <bean> avec initmethod et / ou destroy-methodparamètres. L'attribut init-method spécifie une méthode qui doit être appelée sur le bean immédiatement lors de l'instanciation. De même, destroymethod spécifie une méthode qui est appelée juste avant qu'un bean ne soit supprimé du conteneur.

Rappels d'initialisation

L'interface org.springframework.beans.factory.InitializingBean spécifie une seule méthode -

void afterPropertiesSet() throws Exception;

Ainsi, vous pouvez simplement implémenter l'interface ci-dessus et le travail d'initialisation peut être effectué dans la méthode afterPropertiesSet () comme suit -

public class ExampleBean implements InitializingBean {
   public void afterPropertiesSet() {
      // do some initialization work
   }
}

Dans le cas des métadonnées de configuration XML, vous pouvez utiliser le init-methodattribut pour spécifier le nom de la méthode qui a une signature vide sans argument. Par exemple -

<bean id = "exampleBean" class = "examples.ExampleBean" init-method = "init"/>

Voici la définition de la classe -

public class ExampleBean {
   public void init() {
      // do some initialization work
   }
}

Rappels de destruction

L' interface org.springframework.beans.factory.DisposableBean spécifie une seule méthode -

void destroy() throws Exception;

Ainsi, vous pouvez simplement implémenter l'interface ci-dessus et le travail de finalisation peut être effectué à l'intérieur de la méthode destroy () comme suit -

public class ExampleBean implements DisposableBean {
   public void destroy() {
      // do some destruction work
   }
}

Dans le cas des métadonnées de configuration XML, vous pouvez utiliser le destroy-methodattribut pour spécifier le nom de la méthode qui a une signature vide sans argument. Par exemple -

<bean id = "exampleBean" class = "examples.ExampleBean" destroy-method = "destroy"/>

Voici la définition de la classe -

public class ExampleBean {
   public void destroy() {
      // do some destruction work
   }
}

Si vous utilisez le conteneur IoC de Spring dans un environnement d'application non Web; par exemple, dans un environnement de bureau client riche, vous enregistrez un hook d'arrêt avec la JVM. Cela garantit un arrêt progressif et appelle les méthodes de destruction appropriées sur vos beans singleton afin que toutes les ressources soient libérées.

Il est recommandé de ne pas utiliser les rappels InitializingBean ou DisposableBean, car la configuration XML offre une grande flexibilité en termes de dénomination de votre méthode.

Exemple

Laissez-nous mettre en place un IDE Eclipse fonctionnel et suivez les étapes suivantes pour créer une application Spring -

Pas La description
1 Créez un projet avec un nom SpringExample et créez un package com.tutorialspoint sous lesrc dossier dans le projet créé.
2 Ajoutez les bibliothèques Spring requises à l'aide de l' option Ajouter des JAR externes comme expliqué dans le chapitre Exemple de Spring Hello World .
3 Créez les classes Java HelloWorld et MainApp sous le package com.tutorialspoint .
4 Créez le fichier de configuration Beans Beans.xml sous lesrc dossier.
5 La dernière étape consiste à créer le contenu de tous les fichiers Java et le fichier de configuration Bean et à exécuter l'application comme expliqué ci-dessous.

Voici le contenu de HelloWorld.java fichier -

package com.tutorialspoint;

public class HelloWorld {
   private String message;

   public void setMessage(String message){
      this.message = message;
   }
   public void getMessage(){
      System.out.println("Your Message : " + message);
   }
   public void init(){
      System.out.println("Bean is going through init.");
   }
   public void destroy() {
      System.out.println("Bean will destroy now.");
   }
}

Voici le contenu de la MainApp.javafichier. Ici, vous devez enregistrer un hook d'arrêtregisterShutdownHook()méthode qui est déclarée sur la classe AbstractApplicationContext. Cela garantira un arrêt progressif et appellera les méthodes de destruction appropriées.

package com.tutorialspoint;

import org.springframework.context.support.AbstractApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

public class MainApp {
   public static void main(String[] args) {
      AbstractApplicationContext context = new ClassPathXmlApplicationContext("Beans.xml");

      HelloWorld obj = (HelloWorld) context.getBean("helloWorld");
      obj.getMessage();
      context.registerShutdownHook();
   }
}

Voici le fichier de configuration Beans.xml requis pour les méthodes init et destroy -

<?xml version = "1.0" encoding = "UTF-8"?>

<beans xmlns = "http://www.springframework.org/schema/beans"
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://www.springframework.org/schema/beans
   http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">

   <bean id = "helloWorld" class = "com.tutorialspoint.HelloWorld" init-method = "init" 
      destroy-method = "destroy">
      <property name = "message" value = "Hello World!"/>
   </bean>

</beans>

Une fois que vous avez terminé de créer les fichiers de configuration source et bean, laissez-nous exécuter l'application. Si tout va bien avec votre application, elle imprimera le message suivant -

Bean is going through init.
Your Message : Hello World!
Bean will destroy now.

Méthodes d'initialisation et de destruction par défaut

Si vous avez trop de beans ayant des méthodes d'initialisation et / ou de destruction avec le même nom, vous n'avez pas besoin de déclarer init-method et destroy-methodsur chaque haricot individuel. Au lieu de cela, le cadre offre la flexibilité de configurer une telle situation en utilisantdefault-init-method et default-destroy-method attributs sur l'élément <beans> comme suit -

<beans xmlns = "http://www.springframework.org/schema/beans"
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://www.springframework.org/schema/beans
   http://www.springframework.org/schema/beans/spring-beans-3.0.xsd"
   default-init-method = "init" 
   default-destroy-method = "destroy">

   <bean id = "..." class = "...">
      <!-- collaborators and configuration for this bean go here -->
   </bean>
   
</beans>