您好,登錄后才能下訂單哦!
這篇文章主要講解了“java的原子性、可見性、有序性概念是什么”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“java的原子性、可見性、有序性概念是什么”吧!
原子性
原子性是指一個線程的操作是不能被其他線程打斷,同一時間只有一個線程對一個變量進行操作。在多線程情況下,每個線程的執行結果不受其他線程的干擾,比如說多個線程同時對同一個共享成員變量n++100次,如果n初始值為0,n最后的值應該是100,所以說它們是互不干擾的,這就是傳說的中的原子性。但n++并不是原子性的操作,要使用AtomicInteger保證原子性。
可見性
可見性是指某個線程修改了某一個共享變量的值,而其他線程是否可以看見該共享變量修改后的值。在單線程中肯定不會有這種問題,單線程讀到的肯定都是最新的值,而在多線程編程中就不一定了。
每個線程都有自己的工作內存,線程先把共享變量的值從主內存讀到工作內存,形成一個副本,當計算完后再把副本的值刷回主內存,從讀取到最后刷回主內存這是一個過程,當還沒刷回主內存的時候這時候對其他線程是不可見的,所以其他線程從主內存讀到的值是修改之前的舊值。
像CPU的緩存優化、硬件優化、指令重排及對JVM編譯器的優化,都會出現可見性的問題。
有序性
我們都知道程序是按代碼順序執行的,對于單線程來說確實是如此,但在多線程情況下就不是如此了。為了優化程序執行和提高CPU的處理性能,JVM和操作系統都會對指令進行重排,也就說前面的代碼并不一定都會在后面的代碼前面執行,即后面的代碼可能會插到前面的代碼之前執行,只要不影響當前線程的執行結果。所以,指令重排只會保證當前線程執行結果一致,但指令重排后勢必會影響多線程的執行結果。
雖然重排序優化了性能,但也是會遵守一些規則的,并不能隨便亂排序,只是重排序會影響多線程執行的結果。
感謝各位的閱讀,以上就是“java的原子性、可見性、有序性概念是什么”的內容了,經過本文的學習后,相信大家對java的原子性、可見性、有序性概念是什么這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。