
bean的生命周期:bean的创建 —— 初始化 ——销毁的过程
容器管理bean的生命周期,我们可以自定义初始化和销毁方法,容器在bean进行到当前生命周期就会调用我们的方法
在xml配置文件中是在bean的标签内使用init-method和destroy-method
<bean id="person" class="com.springbean.Person" init-method="" destroy-method="" >
这里我们使用注解的方法
第一种指定初始化和销毁方法
首先创建一个bean
public class Foo { public Foo(){
System.out.println("bean的创建");
} public void init(){
System.out.println("bean的初始化");
} public void destroy(){
System.out.println("bean的销毁");
}
}
创建一个配置类:
@Bean注解上指定初始化和销毁方法
@Configuration
public class MainBeanConfig {
@Bean(initMethod = "init",destroyMethod = "destroy")
public Foo foo(){
return new Foo();
}
}
测试:
public class BeanTest { @Test
public void test(){
ApplicationContext applicationContext = new AnnotationConfigApplicationContext(MainBeanConfig.class);
}
}
bean如果没有指定作用域,就是单例的,就在容器加载的时候就会创建bean,所以打印的结果是:
bean的创建
bean的初始化
销毁:当容器关闭的时候,就会调用destroy方法,打印 bean的销毁
applicationContext.close();
如果要指定bean的作用域为prototype,就需要在配置类中MainBeanConfig,加上注解@Scope("prototype"),如
@Bean
@Scope("prototype")
public Foo foo(){
return new Foo();
}
指定bean的作用域为@Scope("prototype"),这时候容器加载的时候就不会创建和初始化bean,而是在获取bean的时候。 容器关闭的时候也不会去调用destroy方法,需要自己手动调用。
第二种我们通过bean实现InitializingBean(定义初始化逻辑)和DisposableBean(定义销毁逻辑)
创建一个类Hero,实现InitializingBean,DisposableBean接口,加上注解@Component
@Component
public class Hero implements InitializingBean,DisposableBean { public Hero(){
System.out.println("创建");
}
@Override
public void destroy() throws Exception {
System.out.println("销毁");
} @Override
public void afterPropertiesSet() throws Exception {
System.out.println("初始化");
}
}
在配置中加上注解ComponentScan去扫描包,也可以使用@Import来将组件加入容器中
如:@Import({Hero.class})
@ComponentScan("com.springbean")
public class MainBeanConfig {
测试:
@Test
public void test(){
AnnotationConfigApplicationContext applicationContext = new AnnotationConfigApplicationContext(MainBeanConfig.class);
applicationContext.close();
}
打印结果:
创建
初始化
销毁
第三种使用@PostConstruct(构造器创建之后)和@PreDestroy(容器销毁之前)两个注解,这是JSR250的两个注解。
@PostConstruct
public void init(){
System.out.println("bean的初始化");
} @PreDestroy
public void destroy(){
System.out.println("bean的销毁");
}
第四种使用BeanPostProcessor后置处理器,这个接口中有两个方法postProcessBeforeInitialization和postProcessAfterInitialization:
public interface BeanPostProcessor {
Object postProcessBeforeInitialization(Object var1, String var2) throws BeansException; Object postProcessAfterInitialization(Object var1, String var2) throws BeansException;
}
分别在bean初始化之前执行这个方法,这个类似aop里面的前后通知,写一个实现类MyBeanPostProcesser
/**
*后置处理器,处理前后初始化的工作
*/
@Component
public class MyBeanPostProcesser implements BeanPostProcessor {
@Override
public Object postProcessBeforeInitialization(Object o, String s) throws BeansException {
System.out.println(" postProcessBeforeInitialization ...beanname="+s+",bean="+o);
return o;
} @Override
public Object postProcessAfterInitialization(Object o, String s) throws BeansException {
System.out.println("postProcessAfterInitialization.... beanname="+s+",bean="+o);
return o;
}
}
加入到配置类中MainBeanConfig
@Configuration
@Import({Hero.class, MyBeanPostProcesser.class})
public class MainBeanConfig {
测试:输出结果,是在bean的初始化的前后操作
postProcessBeforeInitialization ...beanname=com.springbean.Hero,bean=com.springbean.Hero@4ba2ca36
初始化
postProcessAfterInitialization.... beanname=com.springbean.Hero,bean=com.springbean.Hero@4ba2ca36
