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 分钟前
SmartBi集成到第三方系统
java
一条咸鱼_SaltyFish3 分钟前
大文件性能优化:从百倍提升看底层原理的实践思考
java·性能优化·架构演进·大文件处理·nagle·零对象设计
程序哥聊面试4 分钟前
React + TS 初始化新项目报错解决方法
前端·react.js·npm
codeGoogle5 分钟前
2026 年 IM 怎么选?聊聊 4 家主流即时通讯方案的差异
android·前端·后端
好家伙VCC6 分钟前
**发散创新:用 Rust构建多智能体系统,让分布式协作更高效**在人工智能快速演进的今天,**多智能体系统(
java·人工智能·分布式·python·rust
小沈同学呀7 分钟前
Spring Boot实现加密字段模糊查询的最佳实践
java·spring boot·后端·encrypt
万能的小裴同学9 分钟前
饥荒Mod
java·开发语言·junit
C澒12 分钟前
从单体到分布式:SLDS 2.0 全球物流履约网络架构演进之路
前端·分布式·架构·系统架构·教育电商·交通物流
Jack_David13 分钟前
kafka_2.13-4.1.1集群安装
java·分布式·kafka
HAPPY酷14 分钟前
C++ 高性能消息服务器实战:融合线程、异步与回调的三大核心设计
java·服务器·c++