Spring如何处理线程并发问题?
-
在一般情况下,只有无状态的Bean才可以在多线程环境下共享,在Spring中,绝大部分Bean都可以声明为singleton作用域,因为Spring对一些Bean中非线程安全状态采用ThreadLocal进行处理,解决线程安全问题。
-
ThreadLocal和线程同步机制都是为了解决多线程中相同变量的访问冲突问题。同步机制采用了“时间换空间”的方式,仅提供一份变量,不同的线程在访问前需要获取锁,没获得锁的线程则需要排队。而ThreadLocal采用了“空间换时间”的方式。
-
ThreadLocal会为每一个线程提供一个独立的变量副本,从而隔离了多个线程对数据的访问冲突。因为每一个线程都拥有自己的变量副本,从而也就没有必要对该变量进行同步了。ThreadLocal提供了线程安全的共享对象,在编写多线程代码时,可以把不安全的变量封装进ThreadLocal。
1
2 /***
6 * 单例Bean的情况
7 * 如果在类中声明成员变量 并且有读写操作(有状态),就是线程不安全
8 * 解决:
9 * 1.设置为多例
10 * 2.将成员变量放在ThreadLocal
11 * 3.同步锁 会影响服务器吞吐量
12 * 但是!
13 * 只需要把成员变量声明在方法中(无状态), 单例Bean是线程安全的
14 */
15