Spring Bean的生命周期

一个Bean先要经过Java对象的创建 (也就是通过new关键字创建一个对象),随后根据容器里的配置注入 所需的依赖,最后调用初始化回调 方法,经过这三个步骤才算完成了Bean的初始化。若不再需要这个Bean,则要进行销毁 操作,在正式销毁对象前,会先调用容器的销毁回调方法。

由于Bean的生命周期是交由Spring管理的,所以我们无法像自己控制这些动作时那样任意地在Bean创建后或Bean销毁前增加某些操作。但Spring为我们提供了几种途径,共三种方式。

  1. 实现InitializingBean和DisposableBean接口;
  2. 使用@PostConstruct和@PreDestory注解;
  3. 在<bean/>或@Bean里配置初始化和销毁方法;

我们用代码测试一下第一种方式:

java 复制代码
// 创建一个生命周期类,继承InitializingBean, DisposableBean接口
public class SpringLifeCycle implements InitializingBean, DisposableBean {
    @Override
    public void afterPropertiesSet() throws Exception {
        System.out.println("创建Bean后回调...");
    }

    @Override
    public void destroy() throws Exception {
        System.out.println("销毁Bean前回调...");
    }
}
java 复制代码
@Configuration
public class Application {

    public static void main(String[] args) {
        ApplicationContext ctx = new AnnotationConfigApplicationContext(Application.class);
        if (ctx instanceof ConfigurableApplicationContext) {
            // 关闭容易,测试销毁Bean
            ((ConfigurableApplicationContext) ctx).close();
        }
    }

    @Bean
    public SpringLifeCycle hello() {
        return new SpringLifeCycle();
    }

}

这时我们启动项目

我们已经知道现在SpringLifeCycle类对象已经初始化完成,可以使用了。

我们再测试一下销毁方法,右键运行Application类中的main方法。

发现也成功的在Bean销毁前调用了回调方法。

使用第二种方式也一样:

java 复制代码
public class SpringLifeCycle2 {

    @PostConstruct
    public void initLc() {
        System.out.println("初始化...");
    }

    @PreDestroy
    public void destoryLc() {
        System.out.println("销毁...");
    }

}
相关推荐
政采云技术1 分钟前
Chrome 高阶调试技巧
前端
牧艺2 分钟前
HTML-in-Canvas 深度解析:让 Canvas 真正「吃上」HTML 这碗饭
前端·html·canvas
秦瑜华7 分钟前
前端页面添加AI自动翻译按钮
前端·openai·ai编程
沉浸学习的匿名网友15 分钟前
什么是 .gitignore?为什么每个 Git 项目几乎都离不开它?
前端·git
Apifox35 分钟前
从 Postman 迁移到 Apifox:Workspace、Collection、Environment 现在可以一起导入了
前端·后端·程序员
cidy_982 小时前
Agent\-Reach 保姆级教程|AI Agent 全网数据源扩展工具(免费无调用费)
前端
乘风gg2 小时前
当 AI 遇到私有组件,Cli 才是 AI Coding 的起点
前端·ai编程·cursor
40岁搬砖工2 小时前
直观高效的 VSCode 略缩图定位注释 MARK
前端
前端开发爱好者2 小时前
支持 110 种文件预览!兼容 Vue、React、Svelte!
前端·javascript·vue.js
陈随易4 小时前
VSCode古法神器fnMap v9开发故事
前端·后端·程序员