JAVA并发总览
核心问题
并不是程序的漏洞导致的,而是操作系统底层机制导致的
原子性:
可见性问题:
改的是缓存,但是缓存对另一个线程不可见
有序性问题:
正常应该先创建对象,再赋值;而编译器对指令执行顺序出于某些原因进行了优化,然后改变了执行顺序,如下:
解决方案
可见性:
有序性:
这个原则在加了volatile和锁的时候自动生效,也就是说解决了可见性和原子性,可见性顺带就解决了
原子性:
操作系统角度,监视器的名字是管程
解决了原子性问题,可见性和有序性都能解决
并发工具
CAS的方式会出现ABA问题,就是说是被修改了两次而又变回了原来的值,但是检查是没有变化的,对于引用对象就会出现问题,引用对象地址没变,但是引用的东西发生了变化
其他方案
ThreadLocal,线程是Key,值是线程的数据,每个线程取东西存东西,都是通过线程key区分,来隔离的