java的原子性、可見性、有序性概念是什么

這篇文章主要講解了“java的原子性、可見性、有序性概念是什么”,文中的講解內(nèi)容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“java的原子性、可見性、有序性概念是什么”吧!

創(chuàng)新互聯(lián)是一家專注于網(wǎng)站設計、網(wǎng)站制作與策劃設計,長寧網(wǎng)站建設哪家好?創(chuàng)新互聯(lián)做網(wǎng)站,專注于網(wǎng)站建設10年,網(wǎng)設計領域的專業(yè)建站公司;建站業(yè)務涵蓋:長寧等地區(qū)。長寧做網(wǎng)站價格咨詢:028-86922220

原子性

原子性是指一個線程的操作是不能被其他線程打斷,同一時間只有一個線程對一個變量進行操作。在多線程情況下,每個線程的執(zhí)行結果不受其他線程的干擾,比如說多個線程同時對同一個共享成員變量n++100次,如果n初始值為0,n最后的值應該是100,所以說它們是互不干擾的,這就是傳說的中的原子性。但n++并不是原子性的操作,要使用AtomicInteger保證原子性。

可見性

可見性是指某個線程修改了某一個共享變量的值,而其他線程是否可以看見該共享變量修改后的值。在單線程中肯定不會有這種問題,單線程讀到的肯定都是最新的值,而在多線程編程中就不一定了。

每個線程都有自己的工作內(nèi)存,線程先把共享變量的值從主內(nèi)存讀到工作內(nèi)存,形成一個副本,當計算完后再把副本的值刷回主內(nèi)存,從讀取到最后刷回主內(nèi)存這是一個過程,當還沒刷回主內(nèi)存的時候這時候對其他線程是不可見的,所以其他線程從主內(nèi)存讀到的值是修改之前的舊值。

像CPU的緩存優(yōu)化、硬件優(yōu)化、指令重排及對JVM編譯器的優(yōu)化,都會出現(xiàn)可見性的問題。

有序性

我們都知道程序是按代碼順序執(zhí)行的,對于單線程來說確實是如此,但在多線程情況下就不是如此了。為了優(yōu)化程序執(zhí)行和提高CPU的處理性能,JVM和操作系統(tǒng)都會對指令進行重排,也就說前面的代碼并不一定都會在后面的代碼前面執(zhí)行,即后面的代碼可能會插到前面的代碼之前執(zhí)行,只要不影響當前線程的執(zhí)行結果。所以,指令重排只會保證當前線程執(zhí)行結果一致,但指令重排后勢必會影響多線程的執(zhí)行結果。

雖然重排序優(yōu)化了性能,但也是會遵守一些規(guī)則的,并不能隨便亂排序,只是重排序會影響多線程執(zhí)行的結果。

感謝各位的閱讀,以上就是“java的原子性、可見性、有序性概念是什么”的內(nèi)容了,經(jīng)過本文的學習后,相信大家對java的原子性、可見性、有序性概念是什么這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關知識點的文章,歡迎關注!

新聞名稱:java的原子性、可見性、有序性概念是什么
本文地址:http://muchs.cn/article44/jchche.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供企業(yè)建站、網(wǎng)站制作、面包屑導航、品牌網(wǎng)站制作、網(wǎng)站設計、網(wǎng)站排名

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

搜索引擎優(yōu)化