缓存一致

thinkingme2022年11月4日小于 1 分钟

缓存一致

MESI协议

缓存行对齐

jdk8加入了@Contended,需要加上JVM参数 -XX:-RestrictContended,表示数据独立一个缓存行,防止当保持缓存一致时,一个缓存的失效导致另外无关缓存的失效。因为这两个数据在同一个缓存行上。

示例代码:

/**
 * 缓存行对齐
 */
public class T02_CacheLinePadding {
    private static class Padding {
        public volatile long p1, p2, p3, p4, p5, p6, p7;
    }

    private static class T extends Padding {
        public volatile long x = 0L;
    }

    public static T[] arr = new T[2];

    static {
        arr[0] = new T();
        arr[1] = new T();
    }

    public static void main(String[] args) throws Exception {
        Thread t1 = new Thread(()->{
            for (long i = 0; i < 1000_0000L; i++) {
                arr[0].x = i;
            }
        });

        Thread t2 = new Thread(()->{
            for (long i = 0; i < 1000_0000L; i++) {
                arr[1].x = i;
            }
        });

        final long start = System.nanoTime();
        t1.start();
        t2.start();
        t1.join();
        t2.join();
        System.out.println((System.nanoTime() - start)/100_0000);
    }
}