关于 synchronized 的线程间可见性问题

狼王_ 2017-07-19 04:06:59
JMM关于synchronized的两条规定:

1. 线程解锁前,必须把共享变量的最新值刷新到主内存中
2. 线程加锁时,讲清空工作内存中共享变量的值,从而使用共享变量时需要从主内存中重新读取最新的值。

这样,线程解锁前对共享变量的修改在下次加锁时对其他线程可见。

最后一句: 线程解锁前对共享变量的修改在下次加锁时对其他线程可见。 是什么意思啊? 是说 线程解锁前会将变量的值更新到主内存,下一次其他线程读取该变量的时候强行要求从 主内存中读取,还是说 线程解锁前将 修改后的变量更新到主内存 同时强行将该变量的值更新到各线程的工作内存啊?
...全文
251 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
狼王_ 2017-07-28
  • 打赏
  • 举报
回复
引用 3 楼 qwe885167759 的回复:
意思应该是:在获取到锁的线程释放锁后,他所更新的变量会刷新到主内存去,这会使得其他线程中的缓存中的值变成无效值,当其他线程获得锁后会更新自己缓存中的值。
多谢了!!
岑如花 2017-07-19
  • 打赏
  • 举报
回复
意思应该是:在获取到锁的线程释放锁后,他所更新的变量会刷新到主内存去,这会使得其他线程中的缓存中的值变成无效值,当其他线程获得锁后会更新自己缓存中的值。
狼王_ 2017-07-19
  • 打赏
  • 举报
回复
引用 1 楼 soton_dolphin 的回复:
更简单来讲: 1. 加锁前,从主内存读取共享变量值,刷新线程本地变量值。 2.解锁前,把线程本地变量值写入主内存。
这个我是知道的, 我疑惑的是 线程解锁前对共享变量的修改在下次加锁时对其他线程可见。 这句话 ,其他线程 访问 该共享变量时是从 主内存读取呢 还是 读取自己的工作内存中的 共享变量副本呢?
soton_dolphin 2017-07-19
  • 打赏
  • 举报
回复
更简单来讲: 1. 加锁前,从主内存读取共享变量值,刷新线程本地变量值。 2.解锁前,把线程本地变量值写入主内存。

50,527

社区成员

发帖
与我相关
我的任务
社区描述
Java相关技术讨论
javaspring bootspring cloud 技术论坛(原bbs)
社区管理员
  • Java相关社区
  • 小虚竹
  • 谙忆
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧