Spring中Bean的生命周期

1.初始化和销毁

目标方法执行前和执行后

配置

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xsi:schemaLocation="
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">

<!-- bean definitions here -->
<bean id="User" class="cn.qyc.beansmzq.UserService" init-method="myInit" destroy-method="mydestroy"></bean>
</beans>

bean

package cn.qyc.beansmzq;

public class UserService implements UserServicefactory{

	public void addUser() {
		// TODO Auto-generated method stub
		System.out.println("调用UserService的addUser方法");
	}
	public void myInit() {
		System.out.println("初始化方法");
	}
	public void mydestroy() {
		System.out.println("销毁方法");
	}

}

test

package cn.qyc.beansmzq;

import org.junit.Test;
import org.springframework.context.support.ClassPathXmlApplicationContext;

public class Test01 {
	@Test
	public void demo(){
		String xmlpath = "Bean.xml";
		ClassPathXmlApplicationContext applicationContext = new ClassPathXmlApplicationContext(xmlpath);
		UserService userService = applicationContext.getBean("User",UserService.class);
		userService.addUser();
		applicationContext.close();
	}
}

七月 23, 2019 7:15:37 下午 org.springframework.context.support.AbstractApplicationContext prepareRefresh
信息: Refreshing org.springframework.context.support.ClassPathXmlApplicationContext@29444d75: startup date [Tue Jul 23 19:15:37 CST 2019]; root of context hierarchy
七月 23, 2019 7:15:37 下午 org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions
信息: Loading XML bean definitions from class path resource [Bean.xml]
七月 23, 2019 7:15:37 下午 org.springframework.beans.factory.support.DefaultListableBeanFactory preInstantiateSingletons
信息: Pre-instantiating singletons in org.springframework.beans.factory.support.DefaultListableBeanFactory@4566e5bd: defining beans [User]; root of factory hierarchy
初始化方法
调用UserService的addUser方法

七月 23, 2019 7:15:37 下午 org.springframework.context.support.AbstractApplicationContext doClose
信息: Closing org.springframework.context.support.ClassPathXmlApplicationContext@29444d75: startup date [Tue Jul 23 19:15:37 CST 2019]; root of context hierarchy
七月 23, 2019 7:15:37 下午 org.springframework.beans.factory.support.DefaultSingletonBeanRegistry destroySingletons
信息: Destroying singletons in org.springframework.beans.factory.support.DefaultListableBeanFactory@4566e5bd: defining beans [User]; root of factory hierarchy
销毁方法

2.BeanPostProcessor后处理Bean 

  • spring提供一种机制,只要实现此接口BeanPostProcessor,并将实现类提供给spring容器,spring容器将自动执行,在初始化方法前执行before(),在初始化之后执行after()   
  • 实现:直接配置xml 中 bean的class就可以
  • 后处理bean作用于所有目标类(可以通过参数2  beanName进行控制,使作用于一个)
A a =new A();

a = B.before(a) --> 将a的实例对象传递给后处理bean,可以生成代理对象并返回。

a.init();

a = B.after(a);

a.addUser(); //生成代理对象,目的在目标方法前后执行(例如:开启事务、提交事务)

a.destroy()

配置文件 

<bean id="user" class="cn.qyc.beansmzq.UserService" init-method="myInit" destroy-method="mydestroy"></bean>
<bean class="cn.qyc.beansmzq.MyBeanPostProcessor"></bean>

接口

package cn.qyc.beansmzq;

public interface UserServicefactory {
	public void addUser();
	public void myInit();
	public void mydestroy();
}

实现接口

package cn.qyc.beansmzq;

public class UserService implements UserServicefactory{

	public void addUser() {
		// TODO Auto-generated method stub
		System.out.println("调用UserService的addUser方法");
	}
	public void myInit() {
		System.out.println("初始化方法");
	}
	public void mydestroy() {
		System.out.println("销毁方法");
	}

}

MyBeanPostProcessor

package cn.qyc.beansmzq;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;

import org.springframework.beans.BeansException;
import org.springframework.beans.factory.config.BeanPostProcessor;



public class MyBeanPostProcessor implements BeanPostProcessor{

	public Object postProcessBeforeInitialization(Object bean, String beanname) throws BeansException {
		// TODO Auto-generated method stub
		System.out.println("调用after()" +beanname);
		return bean;
	}

	public Object postProcessAfterInitialization(final Object bean, String beanname) throws BeansException {
		// TODO Auto-generated method stub
		System.out.println("调用before()"+beanname);
		return Proxy.newProxyInstance(
				MyBeanPostProcessor.class.getClassLoader(),
				bean.getClass().getInterfaces(),
				new InvocationHandler() {
			
			public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
				// TODO Auto-generated method stub
				System.out.println("开启事务");
				Object object = method.invoke(bean, args);
				System.out.println("提交事务");
				return object;
			}
		});
//		return bean;
	}

}

test(注意类型为接口类型)

package cn.qyc.beansmzq;

import org.junit.Test;
import org.springframework.context.support.ClassPathXmlApplicationContext;

public class Test01 {
	@Test
	public void demo(){
		String xmlpath = "Bean.xml";
		ClassPathXmlApplicationContext applicationContext = new ClassPathXmlApplicationContext(xmlpath);
		UserServicefactory userService = (UserServicefactory) applicationContext.getBean("user");
		userService.addUser();
		applicationContext.close();
	}
}

七月 23, 2019 8:42:02 下午 org.springframework.context.support.AbstractApplicationContext prepareRefresh
信息: Refreshing org.springframework.context.support.ClassPathXmlApplicationContext@29444d75: startup date [Tue Jul 23 20:42:02 CST 2019]; root of context hierarchy
七月 23, 2019 8:42:02 下午 org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions
信息: Loading XML bean definitions from class path resource [Bean.xml]
七月 23, 2019 8:42:02 下午 org.springframework.beans.factory.support.DefaultListableBeanFactory preInstantiateSingletons
信息: Pre-instantiating singletons in org.springframework.beans.factory.support.DefaultListableBeanFactory@ff5b51f: defining beans [user,cn.qyc.beansmzq.MyBeanPostProcessor#0]; root of factory hierarchy
调用after()user
初始化方法
调用before()user
开启事务
调用UserService的addUser方法
提交事务

七月 23, 2019 8:42:02 下午 org.springframework.context.support.AbstractApplicationContext doClose
信息: Closing org.springframework.context.support.ClassPathXmlApplicationContext@29444d75: startup date [Tue Jul 23 20:42:02 CST 2019]; root of context hierarchy
七月 23, 2019 8:42:02 下午 org.springframework.beans.factory.support.DefaultSingletonBeanRegistry destroySingletons
信息: Destroying singletons in org.springframework.beans.factory.support.DefaultListableBeanFactory@ff5b51f: defining beans [user,cn.qyc.beansmzq.MyBeanPostProcessor#0]; root of factory hierarchy
销毁方法

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 对于SpringBean生命周期Spring在容器有5个生命周期阶段,它们分别是:实例化、属性设置、初始化、销毁以及单例实例化,每个阶段的bean都会触发一个对应的回调事件,让开发者能够在每个阶段做一些额外的处理。 ### 回答2: SpringBean 生命周期包括以下几个阶段: 1. Bean 实例化:Spring 在启动时会通过反射机制实例化 Bean。这是 Bean 生命周期的开始阶段。 2. Bean 属性设置:Spring 在实例化 Bean 后,会根据配置文件或注解等方式,将属性值注入到 Bean 。 3. Bean 初始化前置处理:如果 Bean 实现了 InitializingBean 接口,那么 Spring 会在属性设置完成后调用 Bean 的 afterPropertiesSet() 方法进行初始化前的处理。 4. Bean 初始化后置处理:如果 Bean 配置了 init-method 方法,或者在配置文件通过 init-method 属性指定了初始化方法,那么 Spring 会在初始化前置处理完成后调用该方法。 5. Bean 使用阶段:在初始化完成后,Bean 就可以被应用程序使用了。 6. Bean 销毁前置处理:如果 Bean 实现了 DisposableBean 接口,那么在关闭应用程序或手动销毁 Bean 时,Spring 会先调用 Bean 的 destroy() 方法进行销毁前的处理。 7. Bean 销毁后置处理:如果 Bean 配置了 destroy-method 方法,或者在配置文件通过 destroy-method 属性指定了销毁方法,那么 Spring 会在销毁前置处理完成后调用该方法。 在整个 Bean 生命周期,开发人员可以通过实现 InitializingBean 和 DisposableBean 接口,或者在配置文件指定 init-method 和 destroy-method 方法,来自定义 Bean 的初始化和销毁过程,并在这些过程进行一些特定的操作。 ### 回答3: SpringBean生命周期可以分为以下阶段: 1. 实例化:Spring通过Bean定义创建Bean的实例。这可以通过构造函数实例化,或者通过工厂方法来实现。 2. 属性赋值:SpringBean的属性值注入到Bean的实例。这可以通过依赖注入(DI)方式进行,也可以通过配置文件或注解来实现。 3. 初始化:在Bean实例化和属性赋值之后,Spring会调用Bean的初始化方法。这可以通过实现InitializingBean接口的afterPropertiesSet()方法,或者使用@PostConstruct注解来实现。 4. 使用:在初始化完成之后,Bean可以被使用,执行业务逻辑。 5. 销毁:当Bean不再需要时,Spring会调用Bean的销毁方法。这可以通过实现DisposableBean接口的destroy()方法,或者使用@PreDestroy注解来实现。 需要注意的是,在Bean的生命周期,可以通过配置文件或注解来控制Bean的创建和销毁方式。 总的来说,SpringBean生命周期包括实例化、属性赋值、初始化、使用和销毁这几个阶段。通过控制Bean的生命周期,我们可以在合适的时机执行一些特定的操作,如初始化资源、释放资源等。这样可以有效地管理Bean的生命周期,提高系统的性能和可维护性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值