高级java必须清楚的概念:原子性、可见性、有序性
轉載自?高級java必須清楚的概念:原子性、可見性、有序性
原子性、可見性、有序性是多線程編程中最重要的幾個知識點,由于多線程情況復雜,如何讓每個線程能看到正確的結果,這是非常重要的。
原子性
原子性是指一個線程的操作是不能被其他線程打斷,同一時間只有一個線程對一個變量進行操作。在多線程情況下,每個線程的執行結果不受其他線程的干擾,比如說多個線程同時對同一個共享成員變量n++100次,如果n初始值為0,n最后的值應該是100,所以說它們是互不干擾的,這就是傳說的中的原子性。但n++并不是原子性的操作,要使用AtomicInteger保證原子性。
可見性
可見性是指某個線程修改了某一個共享變量的值,而其他線程是否可以看見該共享變量修改后的值。在單線程中肯定不會有這種問題,單線程讀到的肯定都是最新的值,而在多線程編程中就不一定了。
每個線程都有自己的工作內存,線程先把共享變量的值從主內存讀到工作內存,形成一個副本,當計算完后再把副本的值刷回主內存,從讀取到最后刷回主內存這是一個過程,當還沒刷回主內存的時候這時候對其他線程是不可見的,所以其他線程從主內存讀到的值是修改之前的舊值。
像CPU的緩存優化、硬件優化、指令重排及對JVM編譯器的優化,都會出現可見性的問題。
有序性
我們都知道程序是按代碼順序執行的,對于單線程來說確實是如此,但在多線程情況下就不是如此了。為了優化程序執行和提高CPU的處理性能,JVM和操作系統都會對指令進行重排,也就說前面的代碼并不一定都會在后面的代碼前面執行,即后面的代碼可能會插到前面的代碼之前執行,只要不影響當前線程的執行結果。所以,指令重排只會保證當前線程執行結果一致,但指令重排后勢必會影響多線程的執行結果。
雖然重排序優化了性能,但也是會遵守一些規則的,并不能隨便亂排序,只是重排序會影響多線程執行的結果。
總結
以上是生活随笔為你收集整理的高级java必须清楚的概念:原子性、可见性、有序性的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: java多线程中的死锁、活锁、饥饿、无锁
- 下一篇: 房屋租备案赁需要提供什么(房屋租备案)