System.out.println影响内存可见性

本文探讨了`System.out.println()`如何影响Java内存模型中的内存可见性。通过一个示例程序展示了当注释掉println时,程序因缺少内存屏障导致线程无法感知主内存变化,从而阻塞。而println由于内部的同步机制,实际上起到了内存屏障的作用,强制刷新工作内存,确保了内存可见性。了解这一特性对于理解多线程和并发编程至关重要。
摘要由CSDN通过智能技术生成

看到这个说明你正在学习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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值