java volatile原子性问题

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

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

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

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

volatile 不保证原子性啊

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