The scope of a Bean refers to a certain behavior mode of the Bean in the entire Spring framework.
For example, the singleton scope means that there is only one copy of the Bean in the entire Spring, and it is globally shared. Then when someone else modifies the value, what the other person reads is the modified value.
singleton: singleton scope (default scope)
Bean is in singleton state (singleton) by default, that is, everyone uses For the same object, when we learned the singleton mode before, we all knew that using a singleton can greatly improve performance, so the scope of the Bean in Spring is also the singleton mode by default.
application (understand)
websocket (understand)
Singleton scope (singleton) VS global scope (application)
@Scope tag can modify either method or class, and @Scope has two settings MethodUse enumeration settings:
@Scope(ConfigurableBeanFactory.SCOPE_PROTOTYPE)
@Component public class UserBeans { @Scope(ConfigurableBeanFactory.SCOPE_PROTOTYPE) @Bean public User user1() { User user = new User(); user.setId(1); user.setName("Gujiu"); user.setPassword("123456"); return user; } }
@Scope("prototype" )
@Component public class UserBeans { @Scope("prototype") @Bean public User user1() { User user = new User(); user.setId(1); user.setName("Gujiu"); user.setPassword("123456"); return user; } }
xml to register Bean directly
Bean root (scan ) path
Spring: scan and assemble through class annotations
Bean Assemble into the required class (get the operation)
The so-called life cycle refers to a The entire life process of an object from birth to destruction, we call this process the life cycle of an object.Life cycle of Bean:
实现了各种 Aware 通知的方法,如 BeanNameAware、BeanFactoryAware、ApplicationContextAware 的接口方法 [打电话给各个装修的师傅]
执行 BeanPostProcessor 初始化前置方法 [师傅勘察环境, 指定装修方案 (前置工作)]
执行 @PostConstruct 初始化方法,依赖注入操作之后被执行 [两类装修师傅进行装修]
执行自己指定的 init-method 方法 (如果有指定的话) [两类装修师傅进行装修]
执行 BeanPostProcessor 初始化后置方法 [装修之后的清理工作]
使用 Bean [房子可以入住使用了]
销毁 Bean [卖掉房子]
BeanLifeComponent 类:
//@Component public class BeanLifeComponent implements BeanNameAware { @Override public void setBeanName(String s) { System.out.println("执行了通知"); } @PostConstruct public void postConstruct() { System.out.println("执行了 @PostConstruct"); } public void init() { System.out.println("执行了 init-method"); } @PreDestroy public void preDestroy() { System.out.println("执行了销毁方法"); } }
xml
配置:
<?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:content="http://www.springframework.org/schema/context" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context https://www.springframework.org/schema/context/spring-context.xsd"> <bean id="myComponent" class="com.demo.component.BeanLifeComponent" init-method="init" ></bean> </beans>
调用类:
public class App2 { public static void main(String[] args) { ClassPathXmlApplicationContext applicationContext = new ClassPathXmlApplicationContext("spring-config.xml"); BeanLifeComponent beanLifeComponent = applicationContext.getBean("myComponent", BeanLifeComponent.class); System.out.println("使用Bean"); applicationContext.destroy(); } }
运行结果展示:
The above is the detailed content of In-depth analysis and source code analysis of Spring Bean scope and life cycle in Java. For more information, please follow other related articles on the PHP Chinese website!