首页 > 其他 > 详细

指令重排测试 volatile

时间:2021-08-03 22:20:51      阅读:21      评论:0      收藏:0      [点我收藏+]

指令重排测试

/**
 * @description: 指令重排
 * @program: lock-immortal
 * @author: Mikael
 * @date: 2021-08-03 18:55
 **/

public class Disorder {

    private static int x = 0;
    private static int y = 0;
    private static int a = 0;
    private static int b = 0;

    public static void main(String[] args) throws InterruptedException {
        int i = 0;
        for (; ; ) {
            i++;
            a = 0;
            b = 0;
            x = 0;
            y = 0;

            Thread t1 = new Thread(new Runnable() {
                @Override
                public void run() {
                    a = 1;
                    x = b;  //指令重排 先执行这个代码,导致x = 0 y = 0
                }
            });

            Thread t2 = new Thread(new Runnable() {
                @Override
                public void run() {
                    b = 1;
                    y = a;   //指令重排 先执行这个代码,导致x = 0 y = 0
                }
            });
            t1.start();
            t2.start();
            t1.join();
            t2.join();
            /**
             * 我们在正常情况下 x y的值组合
             * x = 0  y = 1
             * x = 1  y = 0
             * x = 1  y = 1
             * 不可能出现 x = 0 y = 0的情况 除非发生指令重排
             */
            String result = "第" + i + "次 (" + x + "," + y + ")";
            if (x == 0 && y == 0){
                System.err.println(result);
                break;
            }else {
                System.out.println(result);
            }
        }
    }
}

技术分享图片

这是执行结果

指令重排测试 volatile

原文:https://www.cnblogs.com/immortal-mode/p/15095734.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!