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

本文討論了使用Maven和Gradle進行Java項目管理,構建自動化和依賴性解決方案,以比較其方法和優化策略。

本文使用Maven和Gradle之類的工具討論了具有適當的版本控制和依賴關係管理的自定義Java庫(JAR文件)的創建和使用。

本文討論了使用咖啡因和Guava緩存在Java中實施多層緩存以提高應用程序性能。它涵蓋設置,集成和績效優勢,以及配置和驅逐政策管理最佳PRA

本文討論了使用JPA進行對象相關映射,並具有高級功能,例如緩存和懶惰加載。它涵蓋了設置,實體映射和優化性能的最佳實踐,同時突出潛在的陷阱。[159個字符]

Java的類上載涉及使用帶有引導,擴展程序和應用程序類負載器的分層系統加載,鏈接和初始化類。父代授權模型確保首先加載核心類別,從而影響自定義類LOA

本文解釋了用於構建分佈式應用程序的Java的遠程方法調用(RMI)。 它詳細介紹了接口定義,實現,註冊表設置和客戶端調用,以解決網絡問題和安全性等挑戰。

本文詳細介紹了用於網絡通信的Java的套接字API,涵蓋了客戶服務器設置,數據處理和關鍵考慮因素,例如資源管理,錯誤處理和安全性。 它還探索了性能優化技術,我

本文詳細介紹了創建自定義Java網絡協議。 它涵蓋協議定義(數據結構,框架,錯誤處理,版本控制),實現(使用插座),數據序列化和最佳實踐(效率,安全性,維護


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

SublimeText3 Linux新版
SublimeText3 Linux最新版

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SublimeText3漢化版
中文版,非常好用

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。