Spring啟動,constructor,@PostConstruct,afterPropertiesSet,onApplicationEvent執行順序


  1. package com.xx;  
  2.   
  3. import javax.annotation.PostConstruct;  
  4. import javax.annotation.Resource;  
  5.   
  6. import org.springframework.beans.factory.InitializingBean;  
  7. import org.springframework.context.ApplicationListener;  
  8. import org.springframework.context.event.ContextRefreshedEvent;  
  9. import org.springframework.stereotype.Component;  
  10.   
  11. import com.xx.service.DemoService;  
  12.   
  13. @Component  
  14. public class InitBeanTest implements InitializingBean,ApplicationListener<ContextRefreshedEvent> {  
  15.   
  16.     @Resource  
  17.     DemoService demoService;  
  18.       
  19.     public InitBeanTest() {     
  20.            System.err.println("----> InitSequenceBean: constructor: "+demoService);     
  21.         }  
  22.   
  23.     @PostConstruct  
  24.     public void postConstruct() {  
  25.         System.err.println("----> InitSequenceBean: postConstruct: "+demoService);  
  26.     }  
  27.   
  28.     @Override  
  29.     public void afterPropertiesSet() throws Exception {  
  30.         System.err.println("----> InitSequenceBean: afterPropertiesSet: "+demoService);  
  31.     }  
  32.   
  33.     @Override  
  34.     public void onApplicationEvent(ContextRefreshedEvent arg0) {  
  35.         System.err.println("----> InitSequenceBean: onApplicationEvent");  
  36.     }  
  37.   
  38. }  

 

執行結果:

----> InitSequenceBean: constructor: null
----> InitSequenceBean: postConstruct: com.yiniu.kdp.service.impl.DemoServiceImpl@40fe544
----> InitSequenceBean: afterPropertiesSet: com.yiniu.kdp.service.impl.DemoServiceImpl@40fe544
----> InitSequenceBean: onApplicationEvent
----> InitSequenceBean: onApplicationEvent

分析:

構造函數是每個類最先執行的,這個時候,bean屬性還沒有被注入

postConstruct優先於afterPropertiesSet執行,這時屬性竟然也被注入了,有點意外

spring很多組建的初始化都放在afterPropertiesSet做。我們在做一些中間件想和spring一起啟動,可以放在這里啟動。

onApplicationEvent屬於應用層的時間,最后被執行,很容易理解。注意,它出現了兩次,為什么?因為bean注入了DemoService,spring容器會被刷新。

換言之onApplicationEvent會被頻繁執行,需要使用它監聽,需要考慮性能問題。

很顯然,這是觀察者模式的經典應用。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM