指令重排序

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了.");
    }
}

  

 

posted @ 2020-07-18 14:48  树之下  阅读(251)  评论(0)    收藏  举报