JVM原理(十九):JVM虛擬機內存模型

1. 硬件的效率與一致性

數據不安全的原因:緩存一致性的問題

共享內存多核系統:在多路處理器系統中,每個處理器都有自己的高速緩存,而他們又共享同一主內存。

線程先后執行結果不一致問題:除了增加高速緩存之外,為了使處理器內部的運算單元能盡量被充分利用,處理器可能會對輸入代碼進行亂序執行(Out-Of-Order Execution)優化,處理器會在計算之后將亂序執行的結果重組,保證該結果與順序執行的結果是一致的,但并不保證程序中各個語句計算的先后順序與輸入代碼中的順序一致,因此如果存在一個計算任務依賴另外一個計算任務的中間結果,那么其順序性并不能靠代碼的先后順序來保證。與處理器的亂序執行優化類似,Java虛擬機的即時編譯器中也有指令重排序( Instruction Reorder)優化。

2. Java內存模型

JDK5之后Java內存模型逐漸完善起來。

2.1. 主內存與工作內存

Java內存模型目的:定義程序中各種變量的訪問規則,即關注在虛擬機中把變量(Java中的實例字段、靜態字段、構成數組的對象元素)值存儲到內存和從內存中取出變量(Java中的實例字段、靜態字段、構成數組的對象元素)值這樣的底層細節。

規定:

  1. Java內存模型規定所有變量都存儲在主內存中。

  2. 線程工作內存中保存了被該線程使用的變量的主內存副本(復制的是引用)。

  3. 線程對變量的所有操作都必須在工作內存中進行,而不能直接讀寫主內存中的數據。

  4. 不同的線程之間也無法直接訪問對方工作內存中的變量。

Java內存與Java內存區域對應的關系:主內存對應于Java堆中的對象實例數據部分,工作內存對應于虛擬機棧中的部分區域。

2.2. 內存間交互操作

一個變量如何從主內存拷貝到工作內存、如何從工作內存同步回主內存這一類的實現細節。

注:Java虛擬機實現時必須保證下面提及的每一種操作都是原子的、不可再分的。

關于上面過程Java內存模型定義了以下8種操作:

  • lock(鎖定):作用于主內存的變量,他把一個變量標識為一條線程獨占的狀態。

  • unlock(解鎖):作用于主內存的變量,它把一個處于鎖定狀態的變量釋放出來,釋放后的變量才可以被其他線程鎖定。

  • read (讀取) :作用于主內存的變量,它把一個變量的值從主內存傳輸到線程的工作內存中,以便隨后的load動作使用。

  • load (載入) :作用于工作內存的變量,它把read操作從主內存中得到的變量值放入工作內存的變量副本中。

  • use(使用):作用于工作內存的變量,它把工作內存中一個變量的值傳遞給執行引擎,每當虛擬機遇到一個需要使用變量的值的字節碼指令時將會執行這個操作。

  • assign (賦值):作用于工作內存的變量,它把一個從執行引擎接收的值賦給工作內存的變量,每當虛擬機遇到一個給變量賦值的字節碼指令時執行這個操作。

  • store (存儲) :作用于工作內存的變量,它把工作內存中一個變量的值傳送到主內存中,以便隨后的write操作使用。

  • write(寫入):作用于主內存的變量,它把store操作從工作內存中得到的變量的值放入主內存的變量中。

Java內存要求read和load或store和write必須按順序執行。

同時Java內存規定在執行上述8種基本操作時必須滿足以下規則:

  • 不允許read和load、store和write操作之 一單獨出現,即不允許一個變量從主內存讀取了但工作內存不接受,或者工作內存發起回寫了但主內存不接受的情況出現。

  • 不允許一個線程丟棄它最近的assign操作,即變量在工作內存中改變了之后必須把該變化同步回主內存。

  • 不允許一個線程無原因地(沒有發生過任何assign操作)把數據從線程的工作內存同步回主內存中。

  • 一個新的變量只能在主內存中“誕生”,不允許在工作內存中直接使用一個未被初始化(load或assign)的變量,換句話說就是對一個變量實施use、store操作之前,必須先執行assign和load操作。

  • 一個變量在同一時刻只允許一條線程對其進行lock操作,但lock操作可以被同一條線程重復執行多次,多次執行lock后,只有執行相同次數unlock操作,變量才會被解鎖。

  • 如果對一個變量執行lock操作,那將會清空工作內存中此變量的值,在執行引擎使用這個變量前,需要重新執行load或assign操 作以初始化變量的值。

  • 如果一個變量事先沒有被lock操作鎖定,那就不允許對它執行unlock操作,也不允許去unlock一個被其他線程鎖定的變量。

  • 對一個變量執行unlock操作之前,必須先把此變量同步回主內存中(執行store、write操作)

基于以上規定,再加上volatile的一些特殊規定,就能準確地描述Java程序中哪些內存訪問操作是安全的

2.3. 對于volatile型變量的特殊規則

關鍵字volatile可以說是Java虛擬機提供的最輕量級別的同步機制。

2.4. 針對long和double型變量的特殊規則

Long和Double的非原子性協定:允許虛擬機將沒有被volatile修飾的64位數據的讀寫操作劃分為兩次32位的操作來進行,即允許虛擬機實現自行選擇是否要保證64位數據類型的load、store、 read和write這四個操作的原子性。

32位虛擬機確實會產生long、double的非原子性訪問的風險。

在實際開發中,除非該數據有明確可知的線程競爭,否則我們在編寫代碼時一般不需要因為這個原因刻意把用到long和double變量專門聲明為volatile。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/41207.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/41207.shtml
英文地址,請注明出處:http://en.pswp.cn/web/41207.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【Python】已解決:nltk.download(‘stopwords‘) 報錯問題

文章目錄 一、分析問題背景二、可能出錯的原因三、錯誤代碼示例四、正確代碼示例五、注意事項 已解決:nltk.download(‘stopwords’) 報錯問題 一、分析問題背景 在使用Python的自然語言處理庫NLTK(Natural Language Toolkit)時&#xff0c…

后端開發常見錯誤

1、解析json字符串要考慮格式不正確,空值情況 2、解析時間字符串要考虎格式和空值 3、使用mybatis的foreach的時候要考慮拼接sql的耗時,尤其是超過10條數據 4、表字段長度,在接口層校驗字段長度, 調用三方系統的報錯要截取報錯…

CentOS 7安裝Elasticsearch7.7.0和Kibana

一. 準備安裝包 elasticsearch和kibana:官網歷史版本找到并下載(https://www.elastic.co/cn/downloads/past-releases#elasticsearch)ik分詞器:GitHub下載(https://github.com/infinilabs/analysis-ik/releases/tag/v…

【大模型】衡量巨獸:解讀評估LLM性能的關鍵技術指標

衡量巨獸:解讀評估LLM性能的關鍵技術指標 引言一、困惑度:語言模型的試金石1.1 定義與原理1.2 計算公式1.3 應用與意義 二、BLEU 分數:翻譯質量的標尺2.1 定義與原理2.2 計算方法2.3 應用與意義 三、其他評估指標:綜合考量下的多元…

設計模式之狀態機模式

一、狀態機模式介紹 狀態機模式(State Machine Pattern)是一種用于描述對象行為的軟件設計模式,屬于行為型設計模式。在狀態機模式中,對象的行為取決于其內部狀態,并且在不同的狀態下,對象可能會有不同的行…

STM32F103C8T6核心板原理圖和PCB分享

PCB圖 原理圖 資料下載地址: 原理圖PCB庫: https://545c.com/d/45573183-61875742-29897c?p7526 (訪問密碼: 7526)

[go-zero] 簡單微服務調用

文章目錄 1.注意事項2.服務劃分及創建2.1 用戶微服務2.2 訂單微服務 3.啟動服務3.1 etcd 服務啟動3.2 微服務啟動3.3 測試訪問 1.注意事項 go-zero微服務的注冊中心默認使用的是Etcd。 本小節將以一個訂單服務調用用戶服務來簡單演示一下,其實訂單服務是api服務&a…

Java 使用sql查詢mongodb

在現代應用開發中,關系型數據庫和NoSQL數據庫各有千秋。MongoDB作為一種流行的NoSQL數據庫,以其靈活的文檔模型和強大的擴展能力,受到廣泛歡迎。然而,有時開發者可能更熟悉SQL查詢語法,或者需要在現有系統中復用SQL查詢…

【ARMv8/v9 GIC 系列 5.6 -- GIC 超優先級中斷詳細介紹】

請閱讀【ARM GICv3/v4 實戰學習 】 文章目錄 Interrupt superpriority超優先級中斷的特性和應用Physical interface interrupt signalsPhysical Group 1 Non-NMI for Current Security StatePhysical Group 1 for Other Security State, or a Group 0 Non-NMIPhysical Group 1 …

進程控制-wait和waitpid進程回收

wait 阻塞函數 函數作用: 1. 阻塞并等待子進程退出 2. 回收子進程殘留資源 3. 獲取子進程結束狀態(退出原因) pid_t wait(int *wstatus); 返回值: ‐1 : 回收失敗,已經沒有子進程了 >0 : 回收子進程對應的…

一種非凸全變差正則化的信號降噪方法(以模擬信號和軸承振動信號為例,MATLAB)

以旋轉機械振動信號為例,由于旋轉機械運行中背景噪聲較強,振動信號需要進行降噪處理。常用的小波閾值降噪會在信號的不連續處產生虛假的波峰和偽吉布森震蕩,而奇異值分解SVD去噪容易產生虛假分量,全變差去噪則不會出現這樣的情況&…

美國大選特色

美國總統是間接民選的。選民不直接投票選舉總統,而是通過選舉一個稱為選舉人團(Electoral College)的機構成員來間接決定總統。具體過程如下: 1. **選民投票**:在11月的大選日,選民投票選舉他們所在州的選…

深入理解JS逆向代理與環境監測

博客文章:深入理解JS逆向代理與環境監測 1. 引言 首先要明確JavaScript(JS)在真實網頁瀏覽器環境和Node.js環境中有很多使用特性的區別。尤其是在環境監測和對象原型鏈的檢測方面。本文將探討如何使用JS的代理(Proxy&#xff09…

MySQL之備份與恢復(九)

備份與恢復 從備份中恢復 更高級的恢復技術 復制和基于時間點的恢復使用的是相同的技術:服務器的二進制日志。這意味著復制在恢復時會是個非常有幫助的工具,哪怕方式不是很明顯。下面將演示一些可以用到的方法。這里列出來的不是一個完整的列表,但應該…

STM32-USART

本內容基于江協科技STM32視頻學習之后整理而得。 文章目錄 1. 串口通信協議1.1 通信接口1.2 串口通信1.3 硬件電路1.4 電平標準1.5 串口參數及時序1.6 串口時序 2. USART串口通信2.1 USART簡介2.2 USART框圖2.3 USART基本結構2.4 數據幀2.5 數據幀-配置停止位2.6 起始位偵測2.…

DP學習——簡單工廠模式

學而時習之,溫故而知新。 敵人出招(使用場景) 不同的業務場景下要創建不同的對象,但是這些對象又有共同的特點。如何復用代碼呢?你會想到,這些對象可以抽象出一個基類/抽象類就行了,那么隨著業…

【Python】一文向您詳細介紹 argparse中 action=‘store_true’ 的作用

【Python】一文向您詳細介紹 argparse中 action‘store_true’ 的作用 下滑即可查看博客內容 🌈 歡迎蒞臨我的個人主頁 👈這里是我靜心耕耘深度學習領域、真誠分享知識與智慧的小天地!🎇 🎓 博主簡介:98…

pdf怎么轉換成圖片格式文件,pdf文檔怎么轉換成圖片格式

在數字化時代,pdf文件轉換成圖片格式是一種常見的操作,無論是在工作還是日常生活中,我們總會遇到需要將pdf文件轉換為圖片的需求。這可能是因為圖片格式更易于分享、展示或編輯。那么,如何高效地將pdf轉換成圖片呢?本文…

圖神經網絡實戰(16)——經典圖生成算法

圖神經網絡實戰(16)——經典圖生成算法 0. 前言1. 圖生成技術2. Erd?s–Rnyi模型3. 小世界模型小結系列鏈接 0. 前言 圖生成算法是指用于創建模擬圖或網絡結構的算法,這些算法可以根據特定的規則和概率分布生成具有特定屬性的圖&#xff0c…

深度解析:如何利用Python高效挖掘SQLite潛力

Python與SQLite共舞:構建高效輕量級數據庫應用實戰 Python,作為一門優雅且強大的編程語言,搭配輕巧靈活的SQLite數據庫,無疑為我們提供了揮灑創意的完美畫布。今天,咱們就通過一個鮮活的案例,一起探索如何…