Spring启动,constructor,@PostConstruct,afterPropertiesSet,onApplicationEvent执行顺序

[java] view plain copy
  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会被频繁执行,需要使用它监听,需要考虑性能问题。

很显然,这是观察者模式的经典应用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值