文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

SpringBoot中的Bean的初始化与销毁顺序解析

2024-04-02 19:55

关注

我今天学习到SpringBoot里面自定义Bean的初始化与销毁方法

我先总结一下我学到的四种方法:

方法一:

指定init-method 和 destory-method

方法二:

通过让 Bean 实现 InitializingBean 接口,定义初始化逻辑

DisposableBean 接口,定义销毁逻辑

方法三:

用 @PostConstruct,在 Bean 创建完成并且赋值完成后,执行该注解标注的方法

@PreDestroy,在容器销毁 Bean 之前,执行该注解标注的方法

方法四:

通过让 Bean 实现 BeanPostProcessor 接口,在Bean 初始化前后进行一些处理工作

然后我就在想它们的执行顺序是怎样的:

尝试一:

配置类:


//告诉Spring这是一个配置类
@Configuration
public class MainConfigOfLifeCycle {
 
        //利用 init-method 和 destory-method
 @Bean(initMethod="initTest", destroyMethod="detoryTest")
 public Car car() {
  return new Car();
 }
 
        //实现 InitializingBean , DisposableBean 接口
 @Bean
 public Cat cat() {
  return new Cat();
 }
 
        //利用 @PostConstruct ,@PreDestroy
 @Bean
 public Dog dog() {
  return new Dog();
 }
 
        //实现 BeanPostProcessor 接口
 @Bean
 public MyBeanPostProcessor myBeanPostProcessor() {
  return new MyBeanPostProcessor();
 } 
}

4个 bean:


public class Car{ 
 public void initTest() {
  System.out.println(" .. init-method .. ");
 }
 
 public void detoryTest() {
  System.out.println(" .. destory-method .. ");
 }
}
public class Cat implements InitializingBean, DisposableBean {
 
 //该Bean在销毁时,调用
 public void destroy() throws Exception {
  // TODO Auto-generated method stub  
  System.out.println(" .. DisposableBean ..");
 }
 
 //该Bean创建完成并且赋值完成后,调用
 public void afterPropertiesSet() throws Exception {
  // TODO Auto-generated method stub
  
  System.out.println(" .. InitializingBean ..");
 } 
}
public class Dog { 
 //对象创建并赋值之后调用
 @PostConstruct
 public void init() {
  System.out.println(" .. @PostConstruct .. ");
 }
 
 //容器移除对象之前
 @PreDestroy
 public void detory() {
  System.out.println(" .. @PreDestroy .. ");
 } 
}
public class MyBeanPostProcessor implements BeanPostProcessor {
 
 @Override
 public Object postProcessBeforeInitialization(Object bean, String beanName) throws BeansException {
  // TODO Auto-generated method stub
  
  System.out.println(" .. postProcessBeforeInitialization .. ");  
  return bean;
 }
 
 @Override
 public Object postProcessAfterInitialization(Object bean, String beanName) throws BeansException {
  // TODO Auto-generated method stub
  
  System.out.println(" .. postProcessBeforeInitialization .. ");  
  return bean;
 } 
}

运行:


public class IOCTest_LifeCycle { 
 @Test
 public void test01() {
  // 1. 创建IOC容器
  AnnotationConfigApplicationContext applicationContext = new AnnotationConfigApplicationContext(MainConfigOfLifeCycle.class);
  System.out.println("容器创建完成");
 
  // 关闭容器
  applicationContext.close();
 } 
}

执行结果:

思考:发现容器在加载 Bean 时是顺序的,因为我在MainConfigOfLifeCycle这个配置类里 @Bean 是顺序的,所有不能确定这次结果是否准确。

尝试二:我把上面四种方法都杂糅到一个类里

配置类:


@Configuration
public class MainConfigOfLifeCycle { 
 @Bean(initMethod="initTest", destroyMethod="detoryTest")
 public Car car() {
  return new Car();
 }
}

Bean:


public class Car implements InitializingBean, DisposableBean, BeanPostProcessor { 
 public Car() {
  System.out.println("Car 创建");
 }
 
 public void initTest() {
  System.out.println(" .. init-method .. ");
 }
 
 public void detoryTest() {
  System.out.println(" .. destory-method .. ");
 }
 
 @Override
 public void afterPropertiesSet() throws Exception {
  System.out.println(" .. InitializingBean .. ");
 }
 
 @Override
 public void destroy() throws Exception {
  System.out.println(" .. DisposableBean .. ");
 } 
 
 @Override
 public Object postProcessBeforeInitialization(Object bean, String beanName) throws BeansException {
  System.out.println(" .. postProcessBeforeInitialization .. "); 
  return bean;
 }
 
 @Override
 public Object postProcessAfterInitialization(Object bean, String beanName) throws BeansException {
  System.out.println(" .. postProcessAfterInitialization .. "); 
  return bean;
 }
 
 @PostConstruct
 public void postConstructTest() {
  System.out.println(" .. @PostConstruct .. ");
 }
 
 @PreDestroy
 public void preDestroyTest() {
  System.out.println(" .. @PreDestroy .. ");
 } 
}

运行:


public class IOCTest_LifeCycle { 
 @Test
 public void test01() {
  // 1. 创建IOC容器
  AnnotationConfigApplicationContext applicationContext = new AnnotationConfigApplicationContext(MainConfigOfLifeCycle.class);
  System.out.println("容器创建完成");
 
  // 关闭容器
  applicationContext.close();
 } 
}

执行结果:

总结:

创建:

销毁:

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯