线程安全与锁的理解和使用

1,线程安全

线程安全性是指管理数据的状态,
线程安全,其实是指内存中数据的安全,在堆内存中的数据由于可以被任何线程访问到,在没有限制的情况下存在被意外修改的风险。

2,如何解决线程安全的问题

保证线程安全主要是从 :原子性,可见性,有序性研究。
1,私有
例如:局部变量,数据是放在线程的栈内存。A线程来执行这个方法,这些变量会在A的栈内存分配。与此同时,B线程也来执行这个方法,这些变量也会在B的栈内存中分配。
就是说这些局部变量会在每个线程的栈内存中都分配一份。由于线程的栈内存只能自己访问,所以栈内存中的变量只属于自己,其它线程根本就不知道。
所以局部变量肯定是线程安全的。
2,ThreadLocal类
让公共区域堆内存中的数据对于每个线程都是安全的,那就每个线程都拷贝它一份,每个线程只处理自己的这一份拷贝而不去影响别的线程的,这不就安全了。(直白一些,就是把堆内存中的一个数据复制N份,每个线程认领1份,同时规定好,每个线程只能玩自己的那份,不准影响别人的)
3,常量或只读变量,
只能读取,不能修改。它们对于多线程是安全的,想改也改不了
4,加锁:
synchronized 互斥锁,当然也是悲观锁了。
(悲观锁:假设我的数据一定会被意外修改,那干脆直接加锁得了)
如果公共区域(堆内存)的数据,要被多个线程操作时,为了确保数据的安全(或一致)性,需要在数据旁边放一把锁,要想操作数据,先获取锁再说吧。
Synchronized的使用方法:

5,CAS:
在并发很小的情况下,数据被意外修改的概率很低,但是又存在这种可能性,此时就用CAS。CAS其实就是乐观锁。(乐观:假设我的数据不会被意外修改,如果修改了,就放弃,从头再来)

猜你喜欢

转载自blog.csdn.net/weixin_43978695/article/details/109043851