volatile語義

来源:http://www.cnblogs.com/tingyuxuan007/archive/2016/12/04/6132242.html
-Advertisement-
Play Games

volatile在Java記憶體模型(JMM)中,保證共用變數對所有線程可見,但不保證原子性。volatile語義是同步,通過共用變數的方式,完成線程間的通信。 ...



volatile在Java記憶體模型(JMM)中,保證共用變數對所有線程可見,但不保證原子性。volatile語義是同步,通過共用變數的方式,完成線程間的通信。

為什麼需要volatile

Java記憶體模型中抽象、簡化了電腦物理設備,分成工作記憶體和主記憶體,線程有各自的工作記憶體,卻共用主記憶體。如果要把Java記憶體模型與物理設備映射起來的話,L1,L2 Cache可以視為工作記憶體,而L3 Cache視為主記憶體。線程執行指令時,會優先選擇距離 CPU 較近的位置的工作記憶體中使用,而不會從讀寫速度較慢的主記憶體中,我稱之為“就近原則”。當線程指令執行完後,賦值給工作記憶體,如果不回寫到主記憶體,或者通知其他線程,其他線程是無法知曉變數已經修改,仍然會使用曾經緩存在工作記憶體中的變數,這就造成了緩存不一致的問題,Java使用volatile解決這種問題。volatile保證指令賦值完後的變數立即同步回主記憶體中,聲明並通知其他線程當前賦值的變數已經失效,其他線程在下次使用時會放棄工作記憶體中變數,使用主記憶體中的變數。這樣就完成了線程間對於volatile修飾的變數的通信。

可見性

執行引擎只與工作記憶體交互,再有工作記憶體與主記憶體交互。站在執行引擎的角度,與工作記憶體操作完成即表示指令執行完,但是什麼時候工作記憶體會將結果刷新回主記憶體卻不可預測。Java線程間的通信是通過共用記憶體的方式,線程A如果想通知其他所有線程(線程B,線程C)對於變數f的變化情況,需要滿足兩點:

  1. 將變數回寫到主記憶體中
  2. 執行引擎讀取時強制從主記憶體中載入
    在增加了增加了L1、L2 Cache之後,CPU何時將變數從獨享緩存刷新會共用記憶體,獨享緩存是否從共用記憶體載入變數,時間上都是不可確定的,這就造成了緩存不一致的問題。

可見性的語義是線程對變數更新操作後,其他線程是可以獲知變數的變更情況。
工作記憶體和主記憶體關係工作記憶體和主記憶體關係

原子性

原子操作是一個或多個不可中斷的操作,要麼一次性完全執行完畢,要麼就不執行,最終狀態不存在有些操作執行完,有些操作沒有執行,在外部看來是不可分割的整體(比如化學中的原子,當然原子也是可以再分割的,不過站在分子層面,原子是最小的不可分割的),原子操作關註的是不被線程調度器中斷的操作。

原子性操作是不會出現線程交替執行的情況,如果出現線程交替,則說明操作被線程調度器中斷。在Java記憶體模型中,原子性保證你獲取的變數要麼是初始值,要麼是被某一個線程寫入的值,而不會是有多個線程同一時間寫入而產生的混亂結果,long或double類型除外(因為變數的前32位可能由一個線程寫入,後32位由另一個不同的線程寫入),不過加上volatile修飾後的long 和double也具有原子性。

註意:volatile關註可見性,而與原子性沒有關係。volatile關註點在於從工作記憶體刷新回主記憶體,而原子操作關註的是否不被打斷。原子和同步目的都是讓不同線程可以安全地訪問共用變數的兩種處理方式,避免造成記憶體一致性錯誤。

我是葛一凡,希望對你有幫助。

參考

  1. 聊聊併發(一)深入分析Volatile的實現原理
  2. 聊聊併發(五)——原子操作的實現原理
  3. Java Language Specification
  4. Java Volatile 關鍵字詳解
  5. 從緩存行出發理解volatile變數、偽共用False sharing、disruptor
  6. Java併發編程:volatile關鍵字解析
  7. Java 編程要點之併發(Concurrency)詳解
  8. Java 併發編程(1): Java 記憶體模型(JMM)

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 圖片轉字元格式 引言 前幾天看到一幅用字元(準確的說是ascii碼)繪製的doge圖像,覺得挺有意思 將他放到代碼的註釋部分,加上了 的字樣,放在了代碼的註釋部分(新建腳本的時候自動添加),同事看到了覺得挺有意思,問我怎麼搞得。 後來我仔細看了下這幅圖,分析了下,都是用ascii字元繪製的,通過as ...
  • 從本節開始,我們探討文件,本節主要介紹文件的一些基本概念和常識,Java中處理文件的基本思路和類,以及接下來的章節安排思路。 ...
  • 1.sql 2.bean 3.jsp ...
  • 1.web.xml 2.AdminLoginFilter ...
  • 前臺中某些位置可以不登陸就可以訪問,而還有一些模塊只有登入用戶才能訪問! 哪些模塊只有登錄用戶才能訪問: 1.購物車 jsp:/jsp/cart/* servlet:CartItemServlet 2.訂單 jsp:/jsp/order/* servlet:OrderServlet 1.web.xm ...
  • 參考資料:http://blog.csdn.net/tennysonsky/article/details/49685199 ...
  • 本文地址 分享提綱: 1. java環境的搭建 2. java demo代碼運行 3.參考文檔 本人是PHP開發者,一直感覺Java才是程式的王道(應用廣,科班出身),所以終於下決心跟一跟。 主要是給自己看和一些java小白參考,大神勿噴。 1. java環境的搭建 請參考 Java 開發環境配置( ...
  • Java調優經驗談 對於調優這個事情來說,一般就是三個過程: 性能監控:問題沒有發生,你並不知道你需要調優什麼?此時需要一些系統、應用的監控工具來發現問題。 性能分析:問題已經發生,但是你並不知道問題到底出在哪裡。此時就需要使用工具、經驗對系統、應用進行瓶頸分析,以求定位到問題原因。 性能調優:經過 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...