在学习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行为?

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