CPU缓存
cpu运算速度大于内存读写速度,导致cpu花费大量的时间等待从内存读取数据和写入数据。缓存的交换速度比内存快很多,它的出现缓解了这个矛盾。
CPU缓存层级
双核CPU,每个CPU有独立的缓存L1、L2,有共享的缓存L3。在缓存中没有的情况下才会去内存中读取数据。
缓存行
cpu的缓存为了性能一般是以缓存行Cache Line为单位,一次性缓存一块区域的数据。
目前最常用的Cache Line大小为64字节。
缓存一致性
对于缓存行A,如果Cpu1对其中数据a进行修改,Cpu2缓存的数据块会失效,需要重新去内存中读取一次。
缓存一致性协议:https://www.cnblogs.com/z00377750/p/9180644.html
Java多线程验证
同一个缓存行,多线程用时429ms
用数组模拟出多个缓存行的情况,用时246ms
JDK8,可以采用@Contended注解。可以不受cpu缓存行字节数的限制,可以将属性作为独立的缓存行。需要加上:JVM -XX:-RestrictContended
有待验证