指令重排序
java编程语言的语义允许编译器和微处理器执行优化

实例的代码
public class VisibilityDemo2 {
// 状态标识 (不用缓存)
private boolean flag = true;
public static void main(String[] args) throws InterruptedException {
VisibilityDemo2 demo1 = new VisibilityDemo2();
new Thread(new Runnable() {
public void run() {
int i = 0;
while (demo1.flag) {
i++;
}
System.out.println(i);
}
}).start();
TimeUnit.SECONDS.sleep(2);
// 设置is为false,使上面的线程结束while循环
demo1.flag = false;
System.out.println("被置为false了.");
}
}
重排序将run方法的转为 (汇编级别指令重排序)
// 指令重排序
if (demo1.flag){
while (true) {
i++;
}
}
利用volatile关键字修饰变量,保证了需要重排序优化,并且保证了可见性,取消本地的缓存,强制将变量在主内存中更新。可见性即当变量有所改变是,其他有使用到该变量的线程可以立马知道该变量已经改变,再使用该变量的时候,需要到主内存中重新读取。
public class VisibilityDemo2 {
// 状态标识 (不用缓存)
private volatile boolean flag = true;
public static void main(String[] args) throws InterruptedException {
VisibilityDemo2 demo1 = new VisibilityDemo2();
new Thread(new Runnable() {
public void run() {
int i = 0;
while (demo1.flag) {
i++;
}
System.out.println(i);
}
}).start();
TimeUnit.SECONDS.sleep(2);
// 设置is为false,使上面的线程结束while循环
demo1.flag = false;
System.out.println("被置为false了.");
}
}

浙公网安备 33010602011771号