1.1 共同性:
在多线程中,如果不加锁可能会导致线程之间的错乱读取,利用ThreadLocal或synchronized可以保证线程之间读取数据的可靠性和安全性。为什么要加锁的具体介绍
2.1.1synchronized
synchronized 关键字,代表这个方法加锁,相当于不管哪一个线程(例如线程A),运行到这个方法时,都要检查有没有其它线程B(或者C、 D等)正在用这个方法(或者该类的其他同步方法),有的话要等正在使用synchronized方法的线程B(或者C 、D)运行完这个方法后再运行此线程A,没有的话,锁定调用者,然后直接运行
synchronized的特点是将一段代码进行原子化,即在多线程中,必须这段代码执行完才会去执行其他线程。
2.1.2synchronized会造成性能降低:
- 它引入了锁竞争,导致线程在等待锁释放的情况下停止工作,进入阻塞状态,降低了程序的并发性。
- 每次访问 Synchronized 同步代码块时都需要进行额外的锁操作,这会增加额外的开销。
- 它可能会导致不必要的锁竞争,即使锁的粒度可能过大。
2.1.3ThreadLocal
ThreadLocal的介绍
而ThreadLocal并没有锁(保留了并发性),所以它的性能是要高于使用synchronized
3.1ThreadLocal与synchronized的原理:
虽然ThreadLocal模式与synchronized关键字都用于处理多线程并发访问变量的问题,不过两者处理问题的角度和思路不同。
synchronized | ThreadLocal | |
---|---|---|
原理 | 同步机制采用“以时间换空间”的方式,只提供了一份变量,让不同的线程排队访问 | ThreadLocal采用“以时间换空间”的方式,让每个线程都提供了一份变量的副本,从而实现同时访问而互不干扰 |
侧重点 | 多个线程之间访问资源的同步 | 多线程让每个线程之间的数据相互隔离 |
总结:在例子中,虽然使用ThreadLocal和synchronized都能解决问题,但是使用ThreadLocal更为合适,因为这样可以使程序拥有更高的并发性。