提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
文章目录
Cache line
cache line
cpu读取内存指令默认是读取一行,大小为64Byte。
位于同一缓存行的两个不同数据,被两个不同CPU锁定,产生互相影响的伪共享问题
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 < 2; i++) {
arr[0].x = i;
System.out.println("1 " + i);
}
});
Thread t2 = new Thread(()->{
for (long i = 0; i < 2; i++) {
arr[1].x = i;
System.out.println("2 " + i);
}
});
final long start = System.nanoTime();
t1.start();
t2.start();
t1.join();
t2.join();
System.out.println((System.nanoTime() - start)/100_0000);
}
}
public class T01_CacheLinePadding {
private static class T {
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);
}
}
使用缓存行的对齐能够提高效率