spring中的bean是线程安全吗

本文探讨了Spring框架中Bean的线程安全性问题,重点分析了不同作用域(如singleton和prototype)下的线程安全特性,并讨论了@Controller与@Service注解的线程安全问题。

结论: 不是线程安全的

容器本身并没有提供Bean的线程安全策略,谈论Bean是否安全首先看一下它的作用范围:

Spring 的 bean 作用域(scope)类型
  1、singleton:单例,默认作用域。

  2、prototype:原型,每次创建一个新对象。

  3、request:请求,每次Http请求创建一个新对象,适用于WebApplicationContext环境下,在请求完以后,bean会失效并被垃圾回收器回收。

  4、session:会话,同一个会话共享一个实例,不同会话使用不用的实例,session过期,bean会失效。

  5、global-session:全局会话,所有会话共享一个实例。

线程安全这个问题,要从单例与原型Bean分别进行说明。

1. 原型Bean
  对于原型Bean,每次创建一个新对象,也就是线程之间并不存在Bean共享,自然是不会有线程安全的问题。

2. 单例Bean
  对于单例Bean,所有线程都共享一个单例实例Bean,因此是存在资源的竞争。

       但是,我们spring里面的bean大都是无共享变量的,专注于逻辑实现,此时又是线程安全的,这时候,资源竞争会体现在数据库层面。

 

 

变相问题:

@Controller @Service是不是线程安全的? 

答:默认配置下不是的。为啥呢?因为默认情况下@Controller没有加上@Scope,没有加@Scope就是默认值singleton,单例的。意思就是系统只会初始化一次Controller容器,所以每次请求的都是同一个Controller容器,当然是非线程安全的。

 

 

原文地址:https://www.cnblogs.com/myseries/p/11729800.html

SpringBean线程安全性主要取决于Bean的作用域以及Bean本身是否有状态[^2]。 Bean的作用域只是表示Bean的生命周期范围,对于任何生命周期的Bean都是一个对象,这个对象是否线程安全,得看这个Bean对象本身[^1]。对于Singleton作用域的Bean,由于在整个应用程序中只有一个实例,多个线程可能会同时访问该实例,因此需要特别注意多线程访问的线程安全性。如果该Bean是有状态的,那么在多线程环境下可能会出现线程安全问题;如果是无状态的,通常是线程安全的。 对于Prototype作用域和其他作用域,通常更容易确保线程安全性,因为每个线程都有自己的Bean实例,相当于每次请求Bean就相当于new Bean(),这样每个线程操作的都是独立的对象,不会相互影响,从而保证了线程的安全[^2][^3]。 如果Bean是有状态的,开发人员可以通过改变bean的作用域,把 "singleton" 改为 "prototype" 来保证线程安全。修改spring配置文件,把bean的作用域改为prototype的示例如下: ```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:context="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 http://www.springframework.org/schema/context/spring-context.xsd"> <bean id="counter" class="constxiong.interview.threadsafe.Counter" scope="prototype"/> </beans> ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值