Java內存模型–快速概述和注意事項

在計算中, 內存模型描述了線程如何通過內存進行交互,或更一般地,它指定了為分段內存或分頁內存平臺生成代碼時允許編譯器進行的假設。 在給定程序和該程序的執行跟蹤的情況下,它實質上描述了執行跟蹤是否是該程序的合法執行。

Java內存模型描述了Java編程語言中的線程如何通過內存進行交互。 連同代碼的單線程執行描述一起,內存模型提供了Java編程語言的語義。 最初的Java內存模型開發于1995年,人們普遍認為它已損壞,從而阻止了許多運行時優化,并且沒有為代碼安全性提供足夠有力的保證。 它通過Java社區流程進行了更新,即Java規范請求133(JSR-133) (于2004年對Tiger(Java 5.0)生效)。

您可以在Java語言規范的“ 線程和鎖 ”一章以及此Java內存模型討論頁面中找到一些非常有用的信息。

現在,讓我們從“ The Khangaonkar Report ”中看到我們最新的JCG合作伙伴 Manoj提供的有關該主題的一些見解。

(注意:對原始帖子進行了少量編輯以提高可讀性)

Java內存模型描述了定義多個線程寫入和讀取變量時如何看待寫入內存的規則。

當線程讀取變量時,它不一定從內存中獲取最新值。 處理器可能返回一個緩存的值。 此外,即使程序員在編寫代碼時先寫入變量,然后讀取變量,但只要編譯器不改變程序語義,就可以對語句重新排序。 處理器和編譯器通常會這樣做以優化性能。 結果,線程可能看不到它期望看到的值。 這可能導致難以修復并發程序中的錯誤。

Java編程語言提供了“ synchronized”,“ volatile”和“ final”關鍵字來幫助編寫安全的多線程代碼。 但是,由于內存模型未指定,Java的早期版本存在一些問題。 JSR 133(Java內存模型和線程規范修訂版)修復了早期內存模型中的某些缺陷。

大多數程序員都熟悉這樣一個事實,即進入同步塊意味著在監視器上獲得一個鎖,以確保沒有其他線程可以進入同步塊。 不那么熟悉但同樣重要的事實是

(1)獲取鎖并輸入同步塊會強制線程從內存刷新數據。
(2)退出同步塊后,寫入的數據將刷新到內存中。

這確保了同步塊中的線程對同步塊中的其他線程可見。

有沒有聽說過Java上下文中的“ 發生在……之前 ”? JSR 133引入了“之前發生”一詞,并為程序中動作的順序提供了一些保證。 這些保證是:

(1)線程中的每個動作都在該線程之后的所有其他動作之前發生。
(2)顯示器上的解鎖發生在同一顯示器上的后續鎖定之前
(3)對變量的易失性寫入發生在對同一變量的后續易失性讀取之前 (4)對Thread.start()的調用發生在該線程中的任何其他語句之前 (5)線程中的所有動作發生在該線程上的其他任何線程從join()返回之前

術語“動作”在Java語言規范的17.4.2節中定義為可以被其他線程檢測或影響的語句。 正常的讀/寫,易失性的讀/寫,鎖定/解鎖是一些動作。

規則1、4和5保證在單個線程中,所有動作將按照它們在創作程序中出現的順序執行。 規則2和4確保在處理共享數據的多個線程之間,保留同步塊的相對順序以及對易失變量的讀/寫順序。

規則2和規則4使volatile非常類似于同步塊。 在JSR 133之前,volatile仍然意味著對volatile變量的寫操作直接寫到內存中,而讀操作則從內存中讀取。 但是編譯器可能會對非易失性讀/寫進行重新排序,而非易失性讀/寫會導致錯誤的結果。 在JSR 133之后無法使用。

還有一點值得注意。 這與在類的構造函數中初始化的最終成員有關。 只要構造函數正確完成執行,其他線程就可以看到最終成員而無需同步。 但是,如果您從構造函數中共享對對象的引用,則所有選擇都將關閉。

提出的規范描述了線程,鎖,易失性變量和數據競爭的語義。 這包括所謂的Java內存模型 。

相關文章:

  • Cajo,用Java完成分布式計算的最簡單方法
  • Java最佳實踐–高性能序列化
  • Java最佳實踐–字符串性能和精確字符串匹配
  • Java最佳實踐– Vector vs ArrayList vs HashSet
  • Java最佳實踐–隊列之戰和鏈接的ConcurrentHashMap

翻譯自: https://www.javacodegeeks.com/2011/02/java-memory-model-quick-overview-and.html

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

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

相關文章

6-7 統計某類完全平方數 (20 分)

本題要求實現一個函數,判斷任一給定整數N是否滿足條件:它是完全平方數,又至少有兩位數字相同,如144、676等。 函數接口定義: int IsTheNumber ( const int N );其中N是用戶傳入的參數。如果N滿足條件,則該…

C#中數組、ArrayList和List三者的區別(轉) ,加修改

在C#中數組&#xff0c;ArrayList&#xff0c;List都能夠存儲一組對象&#xff0c;那么這三者到底有什么樣的區別呢。 數組 數組在C#中最早出現的。在內存中是連續存儲的&#xff0c;所以它的索引速度非常快&#xff0c;而且賦值與修改元素也很簡單。 <span style"font…

phpmyadmin mysql Access denied for user 'root'@'localhost'問題解決

centos6.4 32位的vps上裝了lnmp以后&#xff0c;phpmyadmin無法連接mysql服務器&#xff0c;ssh命令行里mysql -uroot -p 命令后老是出現拒絕連接的情況。php程序里也是拒絕連接。嘗試過修改phpmyadmin的config.inc.php文件&#xff0c;嘗試過修改my.cnf文件&#xff0c;嘗試過…

帶有Spring和Maven教程的JAX–WS

Spring框架通過JAX-WS提供對Web服務的遠程支持&#xff0c;實際上&#xff0c;如Spring 參考文檔中所述 &#xff0c;有三種將Spring POJO服務公開為JAX-WS Web服務的方式&#xff1a; 公開基于Servlet的Web服務&#xff08;適用于Java EE 5環境&#xff09; 導出獨立的Web服…

7-2 然后是幾點 (15 分)

7-2 然后是幾點 (15 分) 有時候人們用四位數字表示一個時間&#xff0c;比如 1106 表示 11 點零 6 分。現在&#xff0c;你的程序要根據起始時間和流逝的時間計算出終止時間。 讀入兩個數字&#xff0c;第一個數字以這樣的四位數字表示當前時間&#xff0c;第二個數字表示分鐘…

CXF學習(2) helloworld

0.新建一個項目取名wsserver. pom.xml 文件如下 <project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation"http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd…

Hive 接口介紹(Web UI/JDBC)

Hive 接口介紹&#xff08;Web UI/JDBC&#xff09; 實驗簡介 本次實驗學習 Hive 的兩種接口&#xff1a;Web UI 以及 JDBC。 一、實驗環境說明 1. 環境登錄 無需密碼自動登錄&#xff0c;系統用戶名shiyanlou&#xff0c;密碼shiyanlou 2. 環境介紹 本實驗環境采用帶桌面的Ubu…

Java最佳實踐– Char到Byte和Byte到Char的轉換

在使用Java編程語言時&#xff0c;我們將繼續討論與建議的實踐有關的系列文章&#xff0c;我們將討論String性能調優。 特別是&#xff0c;我們將重點介紹使用默認編碼時如何有效地處理字符到字節和字節到字符的轉換。 本文總結了兩種提議的自定義方法與兩種經典方法&#xff0…

IOS-C文件的創建于初始化函數.void init() write_file()

//文件初始化 void init(){ FILE * fpNULL; fpfopen("telbook.data", "rb"); int count0; if (fpNULL) //沒有這個文件就把這個文件創建出來 { fpfopen("tellbook.data", "wb"); fwrite(&count, sizeof(count), 1, fp); fclose(…

7-3 逆序的三位數 (10 分)

7-3 逆序的三位數 (10 分) 程序每次讀入一個正3位數&#xff0c;然后輸出按位逆序的數字。注意&#xff1a;當輸入的數字含有結尾的0時&#xff0c;輸出不應帶有前導的0。比如輸入700&#xff0c;輸出應該是7。 輸入格式&#xff1a; 每個測試是一個3位的正整數。 輸出格式&a…

拋棄優啟Grub4dos和PE大多數時間可以這樣用

拋棄優啟Grub4dos和PE大多數時間可以這樣用 在能夠進入Windows的情況下&#xff0c;Grub4dos和PE大多數時間可以這樣用 http://yunpan.cn/cyuuUtUQMfmGN 提取碼 c2acGrub4dos的出現顛覆了傳統的EZBOOT光盤啟動模式&#xff0c;很多人用grub4dos來實現優盤啟動&#xff0c;同時g…

Java最佳實踐–隊列之戰和鏈接的ConcurrentHashMap

在使用Java編程語言時&#xff0c;我們將繼續討論與建議的實踐有關的系列文章&#xff0c;我們將在四個具有相關語義的流行Queue實現類之間進行性能比較。 為了使事情變得更現實&#xff0c;我們將在多線程環境下進行測試&#xff0c;以討論和演示如何將ArrayBlockingQueue &am…

HDU 5652 India and China Origins(二分 + BFS)

本文鏈接:http://www.cnblogs.com/Ash-ly/p/5398867.html 題意&#xff1a; 中國和印度之間有一片地方&#xff0c;把這片地方抽象化&#xff0c;于是就可以看成一個N * M矩陣&#xff0c;其中黑色的代表高山不能走過去&#xff0c;白色的代表平原&#xff0c;可以通行,人每次可…

C語言%.2f四舍五入

#include <stdio.h> int main() {double d 1.199;printf("%.2f", d);return 0; }輸出1.20 如果不想讓其四舍五入可以這樣&#xff1a; #include <stdio.h> #include <math.h> int main() {double d 1.199;printf("%.2f", floor(d * 1…

關于使用racthet的push.js

racthet的push是用來跳轉另外一個頁面的效果的。但是必須在服務器的環境下支持。如果想要讓本地html訪問支持的話需要添加 轉載于:https://www.cnblogs.com/djawh/p/4623925.html

休眠自動提交命令強制MySQL在過多的磁盤I / O中運行

親愛的大家&#xff0c; 我敢肯定&#xff0c;你們中的許多人都在使用Hibernate和MySQL&#xff0c;我自己在這里和那里都使用它。 通常&#xff0c;編程模型是不錯的&#xff0c;但是普通的JDBC可以快很多已經不是什么秘密了。 在這篇文章中&#xff0c;我想引起您的注意Hibe…

“應用程序無法正常啟動(oxc000007b)”解決方案

解決方案1 通過“DirectX修復工具 V3.3 標準版”軟件修復。 備注&#xff1a;經過測試&#xff0c;并未解決本人的問題&#xff0c;但是這個方法可能對游戲中缺失相關.dll&#xff08;動態鏈接庫&#xff09;有幫助。 解決方案2&#xff1a; 該問題的出現不適偶然&#xff0c;主…

Linux: dev: cmake: CHECK_LIBRARY_EXISTS

文章目錄 簡介例子源代碼最終調用到的兩個命令如果結果是這里為什么不直接使用rpm查看包呢&#xff1f;需要注意的問題 簡介 https://cmake.org/cmake/help/latest/module/CheckLibraryExists.html 這個方法是在Modules/CheckLibraryExists.cmake文件里定義的一個宏。 最終使用…

7-15 計算圓周率 (15 分)

根據下面關系式&#xff0c;求圓周率的值&#xff0c;直到最后一項的值小于給定閾值。 輸入格式&#xff1a; 輸入在一行中給出小于1的閾值。 輸出格式&#xff1a; 在一行中輸出滿足閾值條件的近似圓周率&#xff0c;輸出到小數點后6位。 輸入樣例&#xff1a; 0.01結尾無…

Struts2的全局結果視圖的配置

1.在struts.xml中的package標簽內添加<global-results/>標簽&#xff0c;將全局結果加進該標簽內&#xff0c;只適用于當前包下。 <package name"customer" namespace"/customer" extends"struts-default" > <global-results>…