搜尋
首頁Javajava教程具體介紹java高並發中volatile的實作原理

這篇文章主要介紹了java 高並發中volatile的實現原理的相關資料,在多線程並發編程中synchronized和Volatile都扮演著重要的角色,Volatile是輕量級的synchronized ,它在多處理器開發中保證了共享變數的“可見性”,需要的朋友可以參考下

##java 高並發中volatile的實現原理

摘要: 在多執行緒並發程式設計中synchronized和Volatile都扮演著重要的角色,Volatile是輕量級的synchronized,它在多處理器開發中保證了共享變數的「可見性」。可見性的意思是當一個執行緒修改一個共享變數時,另一個執行緒可以讀到這個修改的值。它在某些情況下比synchronized的開銷更小

1. 定義:

java

程式語言允許執行緒存取共享變量,為了確保共享變量能被準確和一致的更新,線程應該確保透過排他鎖單獨獲得這個變量。 Java語言提供了volatile,在某些情況下比鎖更方便。如果一個欄位被宣告成volatile,java執行緒記憶體模型確保所有執行緒看到這個變數的值是一致的

2. volatile實作原理

那麼Volatile是如何來保證可見性的呢?在x86處理器下透過工具取得JIT編譯器產生的組譯指令來看看對Volatile進行寫入操作CPU會做什麼事情。

Java程式碼: instance = new Singleton();//instance是volatile變數

彙編程式碼: 0x01a3de1d: movb $0x0,0x1104800(%esi );0x01a3de24: lock addl $0x0,(%esp);

有volatile變數修飾的共享變數進行寫入操作的時候會多第二行彙編程式碼,透過查IA-32

架構軟體開發者手冊可知,lock前綴的指令在多核心處理器下會引發了兩件事情。

將目前處理器

快取行的資料會寫回系統記憶體。

這個寫回記憶體的操作會造成在其他CPU裡快取了該記憶體位址的資料無效。

處理器為了提高處理速度,不直接和記憶體進行通訊,而是先將系統記憶體的資料讀到內部快取(L1,L2或其他)後再進行操作,但操作完後不知道何時會寫到內存,如果對聲明了Volatile變數進行寫入操作,JVM就會向處理器發送一條Lock前綴的指令,將這個變數所在快取行的資料寫回系統記憶體。但是就算寫回到內存,如果其他處理器緩存的值還是舊的,再執行計算操作就會有問題,所以在多處理器下,為了確保各個處理器的緩存是一致的,就會實現緩存一致性協議,每個處理器透過嗅探在匯流排

上傳播的資料來檢查自己快取的值是不是過期了,當處理器發現自己快取行對應的記憶體位址被修改,就會目前處理器的快取行設定成無效狀態,當處理器要對這個資料進行修改操作的時候,會強制重新從系統記憶體裡把資料讀到處理器快取裡。

Lock前綴指令會造成處理器快取回寫到記憶體。 Lock前綴指令導致在執行指令期間,聲言處理器的 LOCK# 訊號。在多處理器環境中,LOCK# 訊號確保在聲言該訊號期間,處理器可以獨佔使用任何共享記憶體。 (因為它會鎖住總線,導致其他CPU不能存取總線,不能存取總線就意味著不能存取系統記憶體),但是在最近的處理器裡,LOCK#信號一般不鎖總線,而是鎖緩存,畢竟鎖總線開銷比較大。在8.1.4章節有詳細說明鎖定操作對處理器快取的影響,對於Intel486和Pentium處理器,在鎖操作時,總是在匯流排上聲言LOCK#訊號。但在P6和最近的處理器中,如果存取的記憶體區域已經快取在處理器內部,則不會聲言LOCK#訊號。相反地​​,它會鎖定這塊內存區域的緩存並回寫到內存,並使用緩存一致性機制來確保修改的原子性,此操作被稱為“緩存鎖定”,緩存一致性機制會阻止同時修改被兩個以上處理器快取的記憶體區域資料。

一個處理器的快取回寫到記憶體會導致其他處理器的快取無效。 IA-32處理器和Intel 64處理器使用MESI(修改,獨佔,共享,無效)控制協定去維護內部快取和其他處理器快取的一致性。在多核心處理器系統中進行操作的時候,IA-32 和Intel 64處理器能嗅探其他處理器存取系統記憶體和它們的內部快取。它們使用嗅探技術保證它的內部緩存,系統記憶體和其他處理器的快取的資料在總線上保持一致。例如在Pentium和P6 family處理器中,如果透過嗅探一個處理器來偵測其他處理器打算寫記憶體位址,而這個位址目前處理共享狀態,那麼正在嗅探的處理器將無效它的快取行,在下次存取相同記憶體位址時,強制執行快取行填充

以上是具體介紹java高並發中volatile的實作原理的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
Java仍然是基於新功能的好語言嗎?Java仍然是基於新功能的好語言嗎?May 12, 2025 am 12:12 AM

Javaremainsagoodlanguageduetoitscontinuousevolutionandrobustecosystem.1)Lambdaexpressionsenhancecodereadabilityandenablefunctionalprogramming.2)Streamsallowforefficientdataprocessing,particularlywithlargedatasets.3)ThemodularsystemintroducedinJava9im

是什麼使Java很棒?關鍵特徵和好處是什麼使Java很棒?關鍵特徵和好處May 12, 2025 am 12:11 AM

Javaisgreatduetoitsplatformindependence,robustOOPsupport,extensivelibraries,andstrongcommunity.1)PlatformindependenceviaJVMallowscodetorunonvariousplatforms.2)OOPfeatureslikeencapsulation,inheritance,andpolymorphismenablemodularandscalablecode.3)Rich

前5個Java功能:示例和解釋前5個Java功能:示例和解釋May 12, 2025 am 12:09 AM

Java的五大特色是多態性、Lambda表達式、StreamsAPI、泛型和異常處理。 1.多態性讓不同類的對象可以作為共同基類的對象使用。 2.Lambda表達式使代碼更簡潔,特別適合處理集合和流。 3.StreamsAPI高效處理大數據集,支持聲明式操作。 4.泛型提供類型安全和重用性,編譯時捕獲類型錯誤。 5.異常處理幫助優雅處理錯誤,編寫可靠軟件。

Java的最高功能如何影響性能和可伸縮性?Java的最高功能如何影響性能和可伸縮性?May 12, 2025 am 12:08 AM

java'stopfeatureSnificallyenhanceItsperformanCandScalability.1)對象 - 方向clincipleslike-polymormormormormormormormormormormormorableableflexibleandscalablecode.2)garbageCollectionAutectionAutoctionAutoctionAutoctionAutoctionAutoctionAutoMenateMememorymanateMmanateMmanateMmanagementButCancausElatemention.3)

JVM內部:深入Java虛擬機JVM內部:深入Java虛擬機May 12, 2025 am 12:07 AM

JVM的核心組件包括ClassLoader、RuntimeDataArea和ExecutionEngine。 1)ClassLoader負責加載、鏈接和初始化類和接口。 2)RuntimeDataArea包含MethodArea、Heap、Stack、PCRegister和NativeMethodStacks。 3)ExecutionEngine由Interpreter、JITCompiler和GarbageCollector組成,負責bytecode的執行和優化。

什麼是使Java安全安全的功能?什麼是使Java安全安全的功能?May 11, 2025 am 12:07 AM

Java'ssafetyandsecurityarebolsteredby:1)strongtyping,whichpreventstype-relatederrors;2)automaticmemorymanagementviagarbagecollection,reducingmemory-relatedvulnerabilities;3)sandboxing,isolatingcodefromthesystem;and4)robustexceptionhandling,ensuringgr

必不可少的Java功能:增強您的編碼技巧必不可少的Java功能:增強您的編碼技巧May 11, 2025 am 12:07 AM

Javaoffersseveralkeyfeaturesthatenhancecodingskills:1)對象 - 方向 - 方向上的allowslowsmodelowsmodelingreal-worldentities

JVM最完整的指南JVM最完整的指南May 11, 2025 am 12:06 AM

thejvmisacrucialcomponentthatrunsjavacodebytranslatingitolachine特定結構,影響性能,安全性和便攜性。 1)theclassloaderloader,links andinitializesClasses.2)theexecutionEngineExecutionEngineExecutionEngineExecuteNexeCuteByteCuteByteCuteByTecuteByteCuteByteCuteBytecuteBytecuteByteCoDeinintolachineinstructionsions.3)Memo.3)Memo

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中