并发编程的三大特性
- 可见性
- 有序性
- 原子性
可见性
为什么会有可见性问题?
多核CPU 为了提升CPU效率,设计了L1,L2,L3三级缓存,如图。
如果俩个核几乎同时操作同一块内存,cpu1修改完,当下是对cpu2不可见的。
为了解决这个问题,CPU厂商设置了缓存一致性协议.
缓存一致性协议
有序性
为什么会有有序性问题?
CPU在操作内存时,因为cpu高速内存的传输效率(寄存器)要比内存的效率快得多,
所以cpu在等待内存传输的过程中,也会顺序执行一些其他内存操作,
简单理解就是:为了提升CPU的利用效率,可能会导致原定操作的乱序
object = new Object的顺序操作
- new 开辟一块空间并赋默认值(null, 0)
- 调用构造方法并赋初始值
- 返回内存地址给变量
volatitle关键字
volatitle关键字怎么保证可见性的?
其实使用的是缓存一致性协议
简单