张三疯1dfd
2015-06-03 16:11
采纳率: 66.7%
浏览 2.7k
已采纳

java volatile原子性问题

i++;加法运算,当并发操作的时候,加上volatile为什么不能保证原子性,假如线程A从主存中拿到i为1,
线程A没有进行加法运算,被阻塞了,线程B也从主存中拿到i值为1,然后进行加1运算,将
结果刷新到主存中,这个时候线程B修改i值后,根据MESI协议,应该会将线程A工作内存
缓存行置为无效状态的啊,然后线程A重新到内存中读取最新数据2进行加1操作,为什么线程
A还会按照工作内存原先读取到的1进行加1操作,原子性得不到保证?
volatile只能保证读取到的数据是最新的,不能保证操作的原子性该怎么理解?求大神
指教?

  • 写回答
  • 好问题 提建议
  • 关注问题
  • 收藏
  • 邀请回答

5条回答 默认 最新

  • danielinbiti 2015-06-03 16:32
    已采纳

    volatile只是保证从主内存加载到线程工作内存的值是最新的.
    你也说了“线程A从主存中拿到i为1,线程A没有进行加法运算,被阻塞了”,相当于线程A已经从主存取完值了,这时候主存中数值的更新和线程中的i变量值是没关系了。

    已采纳该答案
    评论
    解决 无用
    打赏 举报
  • Quartzhao 2015-06-03 16:27

    i++操作内部分几个步骤的。tmp=i ;i=i+1 ; return tmp;
    volatile是可以保证一部分原子性的,但只限于一些简单的单步的运算。比如long.double型变量的存取,虽然是64位,可保证原子性

    评论
    解决 无用
    打赏 举报
  • qq_28728717 2015-06-03 16:52

    ++操作内部分几个步骤的。tmp=i ;i=i+1 ; return tmp;
    volatile是可以保证一部分原子性的,但只限于一些简单的单步的运算。比如long.double型变量的存取,虽然是64位,可保证原子性

    评论
    解决 无用
    打赏 举报
  • 请叫我头头哥 2015-06-18 02:53

    i++操作内部分几个步骤的。tmp=i ;i=i+1 ; return tmp;

    评论
    解决 无用
    打赏 举报
  • 咕泡-松阳 2021-07-26 13:22

    volatile 不保证原子性啊

    评论
    解决 无用
    打赏 举报

相关推荐 更多相似问题