volatile关键字
volatile在多线程下保证可见性,可见性,是指线程之间的可见性,一个线程修改的状态对另一个线程是可见的
volatile底层是lock,触发了缓存一致性协议,还可以禁止重排序
缓存行 (Cache Line) 便是 CPU Cache 中的最小单位,CPU Cache 由若干缓存行组成,一个缓存行的大小通常是 64 字节(这取决于 CPU),并且它有效地引用主内存中的一块地址。一个 Java 的 long 类型是 8 字节,因此在一个缓存行中可以存 8 个 long 类型的变量。
在jdk1.8以后可以通过配置jvm参数 -XX:-RestrictContended,加上注解@Contended 避免伪共享
M:代表已修改(Modified):Cache Block 里面的内容我们已经更新过了,但是还没有写回到主内存里面;
E:代表独占(Exclusive):Cache Block 里面的数据和主内存里面的数据是一致的;
S:代表共享(Shared):Cache Block 里面的数据和主内存里面的数据是一致的;
I:代表已失效(Invalidated):Cache Block 里面的数据已经失效了,不可以相信这个 Cache Block 里面的数据;