spring之Bean的生命周期详解

发布时间 - 2026-01-11 01:08:15    点击率:

Bean的生命周期:

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

Bean的定义

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

Bean的初始化

Spring中bean的初始化回调有两种方法

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

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

第一种:

配置文件:

<?xml version="1.0" encoding="UTF-8"?> 
<beans 
  xmlns="http://www.springframework.org/schema/beans" 
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
  xmlns:p="http://www.springframework.org/schema/p" 
  xsi:schemaLocation="http://www.springframework.org/schema/beans  
  http://www.springframework.org/schema/beans/spring-beans-3.0.xsd"> 
 
  <bean id="init-one" class="org.spring.test.BeanInitDemo1" init-method="init"> 
    <property name="message" value="这里是配置文件中为message赋值"></property> 
  </bean> 
</beans> 

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的赋值。

第二种:

配置文件:

<?xml version="1.0" encoding="UTF-8"?> 
<beans 
  xmlns="http://www.springframework.org/schema/beans" 
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
  xmlns:p="http://www.springframework.org/schema/p" 
  xsi:schemaLocation="http://www.springframework.org/schema/beans  
  http://www.springframework.org/schema/beans/spring-beans-3.0.xsd"> 
   
  <bean id="init-two" class="org.spring.test.BeanInitDemo2"> 
    <property name="message" value="这里是配置文件中为message赋值"></property> 
  </bean> 
</beans> 

编写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()方法

第一种:

配置文件:

<?xml version="1.0" encoding="UTF-8"?> 
<beans 
  xmlns="http://www.springframework.org/schema/beans" 
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
  xmlns:p="http://www.springframework.org/schema/p" 
  xsi:schemaLocation="http://www.springframework.org/schema/beans  
  http://www.springframework.org/schema/beans/spring-beans-3.0.xsd"> 
 
  <bean id="destory-one" class="org.spring.test.BeanDestoryDemo1" destroy-method="cleanup"> 
    <property name="message" value="这里是配置文件中为message赋值"></property> 
  </bean> 
</beans> 

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()方法。

第二种:

配置文件:

<?xml version="1.0" encoding="UTF-8"?> 
<beans 
  xmlns="http://www.springframework.org/schema/beans" 
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
  xmlns:p="http://www.springframework.org/schema/p" 
  xsi:schemaLocation="http://www.springframework.org/schema/beans  
  http://www.springframework.org/schema/beans/spring-beans-3.0.xsd"> 
 
  <bean id="destory-two" class="org.spring.test.BeanDestoryDemo2"> 
    <property name="message" value="这里是配置文件中为message赋值"></property> 
  </bean> 
</beans>  

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。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# spring  # bean生命周期  # springbean的生命周期  # bean  # 周期  # Spring Bean生命周期源码原理图解  # Spring与bean有关的生命周期示例详解  # Spring bean生命周期配置过程解析  # 深入了解Spring中Bean的作用域和生命周期  # spring中bean的生命周期详解  # 谈谈我对Spring Bean 生命周期的理解  # 浅谈Spring中Bean的作用域、生命周期  # 浅谈Spring bean 生命周期验证  # 详解Spring中bean生命周期回调方法  # 深入理解Spring中bean的生命周期介绍  # 详解Spring中Bean的生命周期和作用域及实现方式  # 详解Spring 中 Bean 的生命周期  # 配置文件  # 是在  # 中为  # 中对  # 第二种  # 第一种  # 都是  # 加载  # 改变了  # 子类  # 这就是  # 才会  # 两种  # 当你  # 中有  # 如果没有  # 使其  # 实体类  # 有两种  # 你用 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 在Oracle关闭情况下如何修改spfile的参数  黑客如何通过漏洞一步步攻陷网站服务器?  PHP怎么接收前端传的文件路径_处理文件路径参数接收方法【汇总】  简单实现Android验证码  Laravel怎么设置路由分组Prefix_Laravel多级路由嵌套与命名空间隔离【步骤】  Laravel如何生成PDF或Excel文件_Laravel文档导出工具与使用教程  Laravel如何升级到最新的版本_Laravel版本升级流程与兼容性处理  如何实现建站之星域名转发设置?  Laravel如何将应用部署到生产服务器_Laravel生产环境部署流程  如何用5美元大硬盘VPS安全高效搭建个人网站?  深圳防火门网站制作公司,深圳中天明防火门怎么编码?  JS经典正则表达式笔试题汇总  html5如何设置样式_HTML5样式设置方法与CSS应用技巧【教程】  如何用狗爹虚拟主机快速搭建网站?  Laravel如何使用withoutEvents方法临时禁用模型事件  html文件怎么打开证书错误_https协议的html打开提示不安全【指南】  标题:Vue + Vuex 项目中正确使用 JWT 进行身份认证的实践指南  ai格式如何转html_将AI设计稿转换为HTML页面流程【页面】  为什么php本地部署后css不生效_静态资源加载失败修复技巧【技巧】  如何快速辨别茅台真假?关键步骤解析  Python正则表达式进阶教程_复杂匹配与分组替换解析  长沙做网站要多少钱,长沙国安网络怎么样?  Laravel如何集成第三方登录_Laravel Socialite实现微信QQ微博登录  简单实现Android文件上传  Win11怎么关闭资讯和兴趣_Windows11任务栏设置隐藏小组件  如何快速搭建高效可靠的建站解决方案?  Laravel与Inertia.js怎么结合_使用Laravel和Inertia构建现代单页应用  Laravel Octane如何提升性能_使用Laravel Octane加速你的应用  Laravel如何使用缓存系统提升性能_Laravel缓存驱动和应用优化方案  javascript和jQuery中的AJAX技术详解【包含AJAX各种跨域技术】  如何在搬瓦工VPS快速搭建网站?  Laravel模型关联查询教程_Laravel Eloquent一对多关联写法  阿里云高弹*务器配置方案|支持分布式架构与多节点部署  Laravel Seeder填充数据教程_Laravel模型工厂Factory使用  java中使用zxing批量生成二维码立牌  百度输入法ai面板怎么关 百度输入法ai面板隐藏技巧  JavaScript如何实现类型判断_typeof和instanceof有什么区别  高端建站三要素:定制模板、企业官网与响应式设计优化  Laravel集合Collection怎么用_Laravel集合常用函数详解  Windows驱动无法加载错误解决方法_驱动签名验证失败处理步骤  nodejs redis 发布订阅机制封装实现方法及实例代码  Laravel安装步骤详细教程_Laravel环境搭建指南  Python3.6正式版新特性预览  浅谈redis在项目中的应用  如何正确选择百度移动适配建站域名?  微信小程序 五星评分(包括半颗星评分)实例代码  北京网站制作的公司有哪些,北京白云观官方网站?  如何快速查询网站的真实建站时间?  Android自定义listview布局实现上拉加载下拉刷新功能  LinuxShell函数封装方法_脚本复用设计思路【教程】