MESI缓存一致性协议
多个cpu从主内存读取同一个数据到各自的高速缓存,当其中的一个CPU修改了缓存里的数据,该数据会马上同步回主内存,其它CPU通过总线嗅探机制可感知到数据的变化从而将自己缓存里的数据失效
Lock、unLock
总线加lock变成串行,效率降低、store前加lock实现并行
1、防止并发操作,多个线程同时往主线写数据
2、防止store后、还没有写入总线,就已经MESI缓存一致性协议
并发编程的三大特性:可见性、原子性、有序性
volatile保证可见性和有序性,但是不保证原子性,保证原子性需要借助synchronized这样的锁机制
volatile和synchronized的区别
- volatile本质是在告诉jvm当前变量在寄存器(工作内存)中的值是不确定的,需要从主存中读取; synchronized则是锁定当前变量,只有当前线程可以访问该变量,其他线程被阻塞住。
- volatile仅能使用在变量级别;synchronized则可以使用在变量、方法、和类级别的
- volatile仅能实现变量的修改可见性,不能保证原子性;而synchronized则可以保证变量的修改可见性和原子性
- volatile不会造成线程的阻塞;synchronized可能会造成线程的阻塞。
- volatile标记的变量不会被编译器优化;synchronized标记的变量可以被编译器优化