赫尔本 2019-10-30 20:37 采纳率: 0%
浏览 435
已结题

volatile/ java内存模型/ JMM ---代码求解

在学习volatile变量时碰到的疑惑:


1、如下图,按照jmm的理论,因为 changed 这个变量未被volatile修饰,所以子程序的while直接死循环

图片说明

public class ThreadTest {
    // 注意,未被volatile 修饰
    private static boolean changed = false;

    public static void main(String[] args) throws InterruptedException {
        new Thread(() -> {
            System.out.println("子线程变量值: changed = " + changed);
            while (!changed) {
                // 因为changed值未被volatile修饰,所以读到的changed一直是本地线程变量值
            }
            System.out.println("子线程结束。。。");
        }).start();

        System.out.println("主线程变量值:changed = " + changed);

        // sleep 100毫秒,确保子线程已经进入了19行的死循环
        Thread.sleep(100);
        changed = true;
        System.out.println("主线程结束。。。changed = " + changed);

    }
}

2、但是如果在while循环里加上sleep,程序能正常结束

图片说明


public class ThreadTest {
    // 注意,未被volatile 修饰
    private static boolean changed = false;

    public static void main(String[] args) throws InterruptedException {
        new Thread(() -> {
            System.out.println("子线程变量值: changed = " + changed);
            while (!changed) {
                // 因为changed值未被volatile修饰,所以读到的changed一直是本地线程变量值
                try {
                    Thread.sleep(50);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }

            }
            System.out.println("子线程结束。。。changed = " + changed);
        }).start();

        System.out.println("主线程变量值:changed = " + changed);

        // sleep 100毫秒,确保子线程已经进入了19行的死循环
        Thread.sleep(100);
        changed = true;
        System.out.println("主线程结束。。。changed = " + changed);

    }
}


3、所以这是为什么,sleep操作会做触发线程的变量的reload行为?


4、官方文档

图片说明


5、本人vx:17610360027,求大佬解答,困惑多日

  • 写回答

2条回答 默认 最新

  • 关注
    评论

报告相同问题?