i++;加法运算,当并发操作的时候,加上volatile为什么不能保证原子性,假如线程A从主存中拿到i为1,
线程A没有进行加法运算,被阻塞了,线程B也从主存中拿到i值为1,然后进行加1运算,将
结果刷新到主存中,这个时候线程B修改i值后,根据MESI协议,应该会将线程A工作内存
缓存行置为无效状态的啊,然后线程A重新到内存中读取最新数据2进行加1操作,为什么线程
A还会按照工作内存原先读取到的1进行加1操作,原子性得不到保证?
volatile只能保证读取到的数据是最新的,不能保证操作的原子性该怎么理解?求大神
指教?
java volatile原子性问题
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
5条回答 默认 最新
- danielinbiti 2015-06-03 16:32关注
volatile只是保证从主内存加载到线程工作内存的值是最新的.
你也说了“线程A从主存中拿到i为1,线程A没有进行加法运算,被阻塞了”,相当于线程A已经从主存取完值了,这时候主存中数值的更新和线程中的i变量值是没关系了。本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报