zoukankan      html  css  js  c++  java
  • 指令重排序

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

      

  • 相关阅读:
    【File类:重命名功能】
    一段代码-Java
    Galahad
    简单的中位数
    小A的题 线段树区间赋值
    上升子序列方案数
    Superdoku 二分图匹配
    Haybale Guessing 区间并查集
    Dijkstra+二分查找
    莫比乌斯反演
  • 原文地址:https://www.cnblogs.com/shuzhixia/p/13335754.html
Copyright © 2011-2022 走看看