spring bean如何保证并发安全

默认情况下,spring bean创建的都是单例的。

首先,先来了解spring bean的作用域:

spring bean作用域有以下5个:

  • singleton:单例模式,当spring创建applicationContext容器的时候,spring会初始化所有的该作用域实例,加上lazy-init就可以避免预处理;
  • prototype:原型模式,每次通过getBean获取该bean就会新产生一个实例,创建后spring将不再对其管理;
  • request:搞web的大家都应该明白request的域了吧,就是每次请求都新产生一个实例,和prototype不同就是创建后,接下来的管理,spring依然在监听;
  • session:每次会话,同上;
  • global session:全局的web域,类似于servlet中的application。

  1. 如果是web项目,可以Controller类上加注解@Scope("prototype")或@Scope("request")每次从容器中获取该bean时,都会创建一个新的实例,避免了多线程共享同一个对象实例化的问题。这样改造之后的缺点是很大程度上增大了 Bean 创建实例化销毁的服务器资源开销。
  2. 在不改变bean的作用域的情况下,可以避免在bean中存在可变状态的声明。尽量将状态信息存储在方法内部的局部变量中或者使用线程安全的数据结构,比如ConcurrentHashMap、ConcurrentHashSet等等来管理状态。
  3. 使用java并发编程中提供的同步锁机制来保证线程安全性。比如synchronized或者ReentrantLock等来控制对共享状态的访问,从而去确保在同一个时候只有一个线程来访问。

你可能感兴趣的:(JAVASE,spring,java,servlet)