看到这个说明你正在学习java内存模型
先说为什么System.out.println会影响内存可见性
public class ThreadVisibilityTest1 {
public static boolean flag = true;
public static void main(String[] args) throws Exception{
new Thread(
() -> {
System.out.println("子线程执行。。。");
while (flag) {
// System.out.println("123");
}
System.out.println("子线程结束。。。");
}
).start();
Thread.sleep(1000);
flag = false;
System.out.println("已经修改为false");
}
}
不打开注释,正常执行,表现出符合内存可见性的现象
成员变量、静态变量、类信息均会被存储在主内存中;主内存共享的方式是线程各拷贝一份数据到工作内存中,操作完成后就刷新到主内存中
此时程序会一直卡住
打开注释执行程序,会发现程序执行完成,不卡住。
这不符合内存可见性,为什么呢
因为println有一个上锁的操作。使用了 synchronized 上锁会做以下操作:
获得同步锁;
清空工作内存;
从主内存拷贝对象副本到工作内存;
执行代码(计算或者输出等);
刷新主内存数据;
释放同步锁。
所以在有这个的时候会将flag刷新
参考文章列表
java内存模型详解(这是高手)
http://www.hellojava.com/a/77344.html
System.out.println()为何会影响内存可见性
https://blog.csdn.net/qq_28082757/article/details/101065531
内存屏障
https://blog.csdn.net/duzhe2905/article/details/106038681
缓存一致性协议
https://www.cnblogs.com/xrq730/p/7048693.html