Spring原始碼學習之: 通過Spring @PostConstruct 和 @PreDestroy 方法 實現初始化和銷燬bean之前進行的操作

Love Lenka發表於2017-01-03

關於在spring  容器初始化 bean 和銷燬前所做的操作定義方式有三種:

第一種:通過@PostConstruct 和 @PreDestroy 方法 實現初始化和銷燬bean之前進行的操作

第二種是:通過 在xml中定義init-method 和  destory-method方法

第三種是: 通過bean實現InitializingBean和 DisposableBean介面


下面演示通過  @PostConstruct 和 @PreDestory

1:定義相關的實現類:

 

 1     package com.myapp.core.annotation.init;  
 2       
 3     import javax.annotation.PostConstruct;  
 4     import javax.annotation.PreDestroy;  
 5       
 6     public class PersonService {  
 7         
 8         private String  message;  
 9       
10         public String getMessage() {  
11             return message;  
12         }  
13       
14         public void setMessage(String message) {  
15             this.message = message;  
16         }  
17           
18         @PostConstruct  
19         public void  init(){  
20             System.out.println("I'm  init  method  using  @PostConstrut...."+message);  
21         }  
22           
23         @PreDestroy  
24         public void  dostory(){  
25             System.out.println("I'm  destory method  using  @PreDestroy....."+message);  
26         }  
27           
28     }  
View Code

 

2:定義相關的配置檔案:

 1     <?xml version="1.0" encoding="UTF-8"?>  
 2     <beans xmlns="http://www.springframework.org/schema/beans"  
 3     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
 4     xmlns:context="http://www.springframework.org/schema/context"  
 5     xsi:schemaLocation="http://www.springframework.org/schema/beans  
 6     http://www.springframework.org/schema/beans/spring-beans-3.1.xsd  
 7     http://www.springframework.org/schema/context  
 8     http://www.springframework.org/schema/context/spring-context-3.1.xsd">  
 9       
10     <!-- <context:component-scan  base-package="com.myapp.core.jsr330"/> -->  
11       
12     <context:annotation-config />  
13       
14     <bean id="personService" class="com.myapp.core.annotation.init.PersonService">  
15       <property name="message" value="123"></property>  
16     </bean>  
17       
18     </beans>  
View Code

其中<context:annotation-config />告訴spring 容器採用註解配置:掃描註解配置;

測試類:

 

 1     package com.myapp.core.annotation.init;  
 2       
 3     import org.springframework.context.ApplicationContext;  
 4     import org.springframework.context.support.ClassPathXmlApplicationContext;  
 5       
 6     public class MainTest {  
 7           
 8         public static void main(String[] args) {  
 9               
10             ApplicationContext  context = new ClassPathXmlApplicationContext("resource/annotation.xml");  
11               
12             PersonService   personService  =  (PersonService)context.getBean("personService");  
13               
14             personService.dostory();  
15         }  
16       
17     }  
View Code

 

測試結果:

I'm  init  method  using  @PostConstrut....123
I'm  destory method  using  @PreDestroy.....123


其中也可以通過申明載入org.springframework.context.annotation.CommonAnnotationBeanPostProcessor

類來告訴Spring容器採用的 常用 註解配置的方式:

只需要修改配置檔案為:

 

 1     <?xml version="1.0" encoding="UTF-8"?>  
 2     <beans xmlns="http://www.springframework.org/schema/beans"  
 3     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
 4     xmlns:context="http://www.springframework.org/schema/context"  
 5     xsi:schemaLocation="http://www.springframework.org/schema/beans  
 6     http://www.springframework.org/schema/beans/spring-beans-3.1.xsd  
 7     http://www.springframework.org/schema/context  
 8     http://www.springframework.org/schema/context/spring-context-3.1.xsd">  
 9       
10     <!-- <context:component-scan  base-package="com.myapp.core.jsr330"/> -->  
11       
12     <!-- <context:annotation-config /> -->  
13       
14       
15     <bean class="org.springframework.context.annotation.CommonAnnotationBeanPostProcessor" />  
16     <bean id="personService" class="com.myapp.core.annotation.init.PersonService">  
17               <property name="message" value="123"></property>  
18     </bean>  
19       
20       
21       
22     </beans>  
View Code

 

同樣可以得到以上測試的輸出結果。

 

相關文章