1.什么是指令重排序
编译器和处理器为了代码的执行效率会对指令进行重新排序,我们称之为重排序。
public class Demo {
private int a;
private int b;
private int c;
public void a() {
a = 1; //1
b = 2; //2
c = a; //3
b = c + a; //4
System.out.println(b);
}
public static void main(String[] args) {
new Demo().a();
}
}
为了提高代码执行效率,步骤4可能会在步骤3之前执行,我们把这种现象成为指令重排序。
2.重排序的前提条件
数据依赖性(as-if-serial),即在单线程环境下无论以什么顺序执行都保证结果正确,依赖包括,写后读,读后写,写后写。只有满足这个条件才能进行指令重排序。
3.重排序的分类
编译器重排序、处理器重排序。
4.为什么要进行指令重排序
为了提高程序的运行性能。
5.指令重排序带来的影响
指令重排序对于单线程只是单纯地提高了代码的执行效率,对于多线程来说,可能造成代码执行结果错误。
6.竞争与同步
处于竞争状态的代码在进行同步后可以避免重排序在多线程环境下带来的问题。