博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
spring之Bean的生命周期
阅读量:6268 次
发布时间:2019-06-22

本文共 4856 字,大约阅读时间需要 16 分钟。

Bean的生命周期:

Bean的定义——Bean的初始化——Bean的使用——Bean的销毁

Bean的定义

Bean 是 Spring 装配的组件模型,一切实体类都可以配置成一个 Bean ,进而就可以在任何其他的 Bean 中使用,一个 Bean 也可以不是指定的实体类,这就是抽象 Bean 。

Bean的初始化

Spring中bean的初始化回调有两种方法
一种是在配置文件中声明init-method="init",然后在一个实体类中用init()方法来初始化

另一种是实现InitializingBean接口,覆盖afterPropertiesSet()方法。

第一种:

配置文件:

BeanInitDemo1类:

package org.spring.test;public class BeanInitDemo1 {	private String message;	public String getMessage() {		return message;	}	public void setMessage(String message) {		this.message = message;	}	public void init(){		this.setMessage("这里是init()方法初始化设值");	}}
测试类:

package org.spring.test;import org.springframework.context.ApplicationContext;import org.springframework.context.support.ClassPathXmlApplicationContext;public class Test {	public static void main(String[] args) {		ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");		BeanInitDemo1 bid = (BeanInitDemo1) context.getBean("init-one");		System.out.println(bid.getMessage());	}}
运行结果:
这里是init()方法初始化设值
原因:init()初始化方法的调用是在配置文件的Bean初始化之后执行的, 所以改变了配置文件中对message的赋值。
第二种:
配置文件:

编写BeanInitDemo2类,使其实现InitializingBean接口

package org.spring.test;import org.springframework.beans.factory.InitializingBean;public class BeanInitDemo2 implements InitializingBean{	private String message;	public String getMessage() {		return message;	}	public void setMessage(String message) {		this.message = message;	}	public void afterPropertiesSet() throws Exception {		// TODO Auto-generated method stub		this.setMessage("这里覆盖了InitializingBean接口的afterPropertiesSet()方法设值");	}	}
测试:

package org.spring.test;import org.springframework.context.ApplicationContext;import org.springframework.context.support.ClassPathXmlApplicationContext;public class Test {	public static void main(String[] args) {		ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");		BeanInitDemo2 bid = (BeanInitDemo2) context.getBean("init-two");		System.out.println(bid.getMessage());	}}
运行结果: 这里覆盖了InitializingBean接口的afterPropertiesSet()方法设值
 原因相同,afterPropertiesSet()方法在配置文件的Bean初始化后执行,所以改变了配置文件中对message的赋值

Bean的使用

Spring中有两种使用bean的方法:

1, BeanFactory:

BeanFactory factory= new XmlBeanFactory(new ClassPathResource("bean.xml"));
factory.getBean("student");
BeanFactory是延迟加载,如果Bean的某一个属性没有注入,BeanFacotry加载后,直至第一次使用getBean方法才会抛出异常,也就是说当使用BeanFactory实例化对象时,配置的bean不会马上被实例化。当你使用该bean时才会被实例化(getBean)。
2, ApplicationContext:

ApplicationContext ac = new ClassPathXmlApplicationContext("bean.xml");
如果使用ApplicationContext,则配置的bean如果是singleton不管你用还是不用,都被实例化。ApplicationContext在初始化自身时检验,这样有利于检查所依赖属性是否注入。ApplicationContext是BeanFactory的子类,除了具有BeanFactory的所有功能外还提供了更完整的框架功能,例如国际化,资源访问等。所以通常情况下我们选择使用ApplicationContext。

Bean的销毁

Bean的销毁和初始化一样,都是提供了两个方法
一是在配置文件中声明destroy-method="cleanup",然后在类中写一个cleanup()方法销毁
二是实现DisposableBean接口,覆盖destory()方法
第一种:
配置文件:

BeanDestoryDemo1类:

package org.spring.test;public class BeanDestoryDemo1 {	private String message;	public String getMessage() {		return message;	}	public void setMessage(String message) {		this.message = message;	}	public void cleanup(){		System.out.println("销毁之前可以调用一些方法");	}}
测试:

package org.spring.test;import org.springframework.context.support.AbstractApplicationContext;import org.springframework.context.support.ClassPathXmlApplicationContext;public class DestortTest {	public static void main(String[] args) {		AbstractApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");		BeanDestoryDemo1 bdd = (BeanDestoryDemo1) context.getBean("destory-one");		System.out.println(bdd.getMessage());		context.registerShutdownHook();	}}
运行结果:

context.registerShutdownHook()是为spring注册关闭吊钩,程序退出之前关闭spring容器,如果没有context.registerShutdownHook();将不会执行cleanup()方法。

第二种:
配置文件:

BeanDestoryDemo2类:

package org.spring.test;import org.springframework.beans.factory.DisposableBean;public class BeanDestoryDemo2 implements DisposableBean{	private String message;	public String getMessage() {		return message;	}	public void setMessage(String message) {		this.message = message;	}	public void destroy() throws Exception {		// TODO Auto-generated method stub		System.out.println("同样,销毁之前调用的方法");	}}
测试:

package org.spring.test;import org.springframework.context.support.AbstractApplicationContext;import org.springframework.context.support.ClassPathXmlApplicationContext;public class DestortTest {	public static void main(String[] args) {		AbstractApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");		BeanDestoryDemo2 bdd = (BeanDestoryDemo2) context.getBean("destory-two");		System.out.println(bdd.getMessage());		context.registerShutdownHook();	}}
运行结果:

Spring可以管理singleton作用域(默认的)的Bean的生命周期,所以在Bean初始化及销毁之前可以做一些工作,更灵活的管理Bean。

你可能感兴趣的文章
轻松精通awk数组企业问题案例
查看>>
26.Azure备份服务器(下)
查看>>
从“网上说的能信么”说开去---学习的思考
查看>>
DHCP 日志分析
查看>>
.NET Micro Framework动态调用C/C++底层代码(原理篇)
查看>>
Windows Server 2012正式版RDS系列⒃
查看>>
Shell脚本之awk篇
查看>>
微软发布Azure Stack硬件需求
查看>>
python socket编程详细介绍
查看>>
Windows Server 2016第三个技术预览版新技术
查看>>
Everything 本地磁盘文件搜索工具下载!
查看>>
Python dict(字典) 详细总结
查看>>
RPF(Reverse Path Forwarding 反向路径转发)技术
查看>>
2016年收到的第一件礼物,被评上微软全球最有价值专家MVP(一)
查看>>
2016中国VR开发者论坛第一期
查看>>
Hyper-V 2016 系列教程5 Hyper-V 服务器基本属性
查看>>
北京、天津工厂自动监测数据爬取
查看>>
第一个python程序简单加法计算器
查看>>
在CentOS下安装Tomcat8
查看>>
Weblogic classloader分析
查看>>