Spring框架的Bean是线程安全的吗?怎么处理线程安全问题?

Spring框架的Bean是线程安全的吗?

默认不是线程安全的,没有使用线程安全策略,因为每个Bean对象默认作用域是singleton,也就是单例的。

Spring中Bean的作用域
  1. singleton:默认,每个容器中只有一个bean的实例,单例的模式由BeanFactory自身来维护。该
    对象的生命周期是与Spring IOC容器一致的(但在第一次被注入时才会创建)。
  2. prototype:为每一个bean请求提供一个实例。在每次注入时都会创建一个新的对象
  3. request:bean被定义为在每个HTTP请求中创建一个单例对象,也就是说在单个请求中都会复用
    这一个单例对象。请求完成后销毁。
  4. session:与request范围类似,确保每个session中有一个bean的实例,在session过期后,bean
    会随之失效。
  5. application:bean被定义为在ServletContext的生命周期中复用一个单例对象。
  6. websocket:bean被定义为在websocket的生命周期中复用一个单例对象。
  7. global-session:全局作用域,global-session和Portlet应用相关。当你的应用部署在Portlet容器
    中工作时,它包含很多portlet。如果你想要声明让所有的portlet共用全局的存储变量的话,那么
    这全局变量需要存储在global-session中。全局作用域与Servlet中的session作用域效果相同。

怎么解决线程安全问题?

具体情况具体分析,如果要处理现场问题

  1. 可以将作用域改成prototype或者其他
  2. 保证Bean对象是无状态的,保证线程安全问题。
  3. 可以将数据存放到ThreadLocal当中,存储到ThreadLocalMap当中,保证线程安全问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值