初步认识Volatile-总结可见性的本质
生活随笔
收集整理的這篇文章主要介紹了
初步认识Volatile-总结可见性的本质
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
由于CPU高速緩存的出現使得?如果多個cpu同時緩存了相同的共享數據時,可能存在可見性問題。也就是CPU0修改了自己本地緩存的值對于CPU1不可見。不可見導致的后果是CPU1后續在對該數據進行寫入操作時,是使用的臟數據。使得數據最終的結果不可預測。?
很多同學肯定希望想在代碼里面去模擬一下可見性的問題,實際上,這種情況很難模擬。因為我們無法讓某個線程指定某個特定CPU,這是系統底層的算法,?JVM應該也是沒法控制的。還有最重要的一點,就是你無法預測CPU緩存什么時候會把值傳給主存,可能這個時間間隔非常短,短到你無法觀察到。最后就是線程的執行的順序問題,因為多線程你無法控制哪個線程的某句代碼會在另一個線程的某句代碼后面馬上執行。
所以我們只能基于它的原理去了解這樣一個存在的客觀事實?了解到這里,大家應該會有一個疑問,剛剛不是說基于緩存一致性協議或者總線鎖能夠達到緩存一致性的要求嗎?為什么還需要加volatile關鍵字?或者說為什么還會存在可見性問題呢?
?
總結
以上是生活随笔為你收集整理的初步认识Volatile-总结可见性的本质的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 初步认识Volatile-缓存一致性协议
- 下一篇: 初步认识Volatile-MESI优化带