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變量值是沒關系了。