现在有一个公共 Bean
@Component
public class UserBean {
@Bean
public User user1() {
User user = new User();
user.setId(1);
user.setName("张三");
user.setAge(18);
return user;
}
}
现在有一个用户1, 进行了修改的操作
@Controller
public class UserControllerA {
@Autowired
private User user1;
public User getUser1() {
User user = user1;
System.out.println("用户1修改之前: " + user1);
user.setName("王五");
return user;
}
}
现在有用户2, 进行读取操作
@Controller
public class UserControllerB {
@Autowired
private User user1;
public User getUser1() {
User user = user1;
return user;
}
}
打印用户1和用户2公共Bean的值
public static void main(String[] args) {
ApplicationContext context = new ClassPathXmlApplicationContext("spring.xml");
UserControllerA userControllerA = context.getBean("userControllerA",UserControllerA.class);
User user = userControllerA.getUser1();
System.out.println("用户1修改之后: " + user);
UserControllerB userControllerB = context.getBean("userControllerB",UserControllerB.class);
User user1 = userControllerB.getUser1();
System.out.println("用户2读取到的: " + user1);
}
运行结果
原因:
Spring 中 Bean 的作用域默认是 singleton 单例模式. 所有人使用的都是同一个对象.
之前所说的作用域, 是在程序中定义的某个变量的某个区域就叫做作用域.这里的Bean作用域不同.
**Bean 的作用域指:**Bean在 Spring 整个框架中的某种行为模式,
比如 singleton 单例作用域, 就表示 Bean 在整个 Spring 中只有一份, 它是全局共享的, 那么当其他人修改了这个值之后, 那么另一个人读取到的就是被修改的值.
Spring 容器在初始化一个 Bean 的示例时, 同时会指定该实例的作用域.
Spring 有 6 种作用域.
singleton
: 单例作用域prototype
: 原型作用域 (多例作用域)request
: 请求作用域session
: 回话作用域application
: 全局作用域websocket
: HTTP WebSocket 作用域3~6 这四种是 Spring MVC 中的值.
@Scope 既可以用于方法注解, 也可以用于类注解
如果是 @Bean + @Scope , 这里的@Scope 就不能写成类注解的方式了.
Bean 的生命周期分为 5 大部分:
xxxAware
)BeanPostProcessor
@PostConstruct
初始化方法nit-mehtod
初始化方法BeanPostProcessor
@PreDestory
DisposableBean
, 执行实现方法destory-method
package com.wwzz.util;
import org.springframework.beans.factory.BeanNameAware;
import org.springframework.stereotype.Component;
import javax.annotation.PostConstruct;
import javax.annotation.PreDestroy;
@Component
public class BeanLifeComponent implements BeanNameAware {
@Override
public void setBeanName(String s) {
System.out.println("执行通知: BeanNameAware " + s);
}
@PostConstruct
public void postConstruct(){
System.out.println("执行 @PostConstruct");
}
public void init() {
System.out.println("执行 init-method");
}
@PreDestroy
public void preDestroy(){
System.out.println("执行 @PreDestroy");
}
public void destroy() {
System.out.println("执行 destroy");
}
}
<?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">
<!-- 配置 Spring 扫描的根路径(此根路径下的所有 Spring 存对象的注解才能生效) -->
<content:component-scan base-package="com.wwzz"></content:component-scan>
<beans>
<bean id="beanLifeComponent" class="com.wwzz.util.BeanLifeComponent" init-method="init" destroy-method="destroy"></bean>
</beans>
</beans>
public static void main(String[] args) {
ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("spring.xml");
BeanLifeComponent beanLifeComponent = context.getBean("beanLifeComponent",BeanLifeComponent.class);
context.destroy();
}
版权说明 : 本文为转载文章, 版权归原作者所有 版权申明
原文链接 : https://wangzhi430.blog.csdn.net/article/details/125062725
内容来源于网络,如有侵权,请联系作者删除!