Java內存模型和優化

總覽

許多多線程代碼開發人員都熟悉這樣的想法,即不同的線程可以對持有的值有不同的看法,這不是唯一的原因,即如果線程不安全,它可能不會看到更改。 JIT本身可以發揮作用。

為什么不同的線程看到不同的值?

當您有多個線程時,它們將嘗試例如通過嘗試訪問同一內存來最小化它們將交互的數量。 為此,他們有一個單獨的
本地副本,例如在1級緩存中。 該緩存通常最終是一致的。 我看到兩個線程看到不同值的短時間介于一微秒到十毫秒之間。 最終,線程被上下文切換,緩存被清除或更新。 無法保證何時會發生這種情況,但幾乎總是不到一秒鐘。

JIT如何發揮作用?

Java內存模型說,不能保證不是線程安全的字段將看到更新。 這允許JIT進行優化,將僅讀取而不寫入的值有效地內聯到代碼中。 這意味著即使更新了緩存,更改也可能不會反映在代碼中。

一個例子

該代碼將一直運行,直到將布爾值設置為false為止。

>static class MyTask implements Runnable {private final int loopTimes;private boolean running = true;boolean stopped = false;public MyTask(int loopTimes) {this.loopTimes = loopTimes;}@Overridepublic void run() {try {while (running) {longCalculation();}} finally {stopped = true;}}private void longCalculation() {for (int i = 1; i < loopTimes; i++)if (Math.log10(i) < 0)throw new AssertionError();}
}public static void main(String... args) throws InterruptedException {int loopTimes = Integer.parseInt(args[0]);MyTask task = new MyTask(loopTimes);Thread thread = new Thread(task);thread.setDaemon(true);thread.start();TimeUnit.MILLISECONDS.sleep(100);task.running = false;for (int i = 0; i < 200; i++) {TimeUnit.MILLISECONDS.sleep(500);System.out.println("stopped = " + task.stopped);if (task.stopped)break;}
}

此代碼反復執行一些對內存沒有影響的工作。 它唯一的區別是需要多長時間。 通過花費更長的時間,它將確定在運行之前或之后將run()中的代碼優化為false。

如果我使用10或100和-XX:+ PrintCompilation運行此命令,則會看到

111    1     java.lang.String::hashCode (55 bytes)
112    2     java.lang.String::charAt (29 bytes)
135    3     vanilla.java.perfeg.threads.OptimisationMain$MyTask :longCalculation (35 bytes)
204    1 % ! vanilla.java.perfeg.threads.OptimisationMain$MyTask :run @ 0 (31 bytes)
stopped = false
stopped = false
stopped = false
stopped = false
... many deleted ...
stopped = false
stopped = false
stopped = false
stopped = false
stopped = false

如果我用1000運行它,您會看到run()尚未編譯并且線程停止

112    1     java.lang.String::hashCode (55 bytes)
112    2     java.lang.String::charAt (29 bytes)
133    3     vanilla.java.perfeg.threads.OptimisationMain $MyTask::longCalculation (35 bytes)
135    1 %   vanilla.java.perfeg.threads.OptimisationMain $MyTask::longCalculation @ 2 (35 bytes)
stopped = true

一旦線程被編譯,即使線程將進行多次上下文切換等,更改也永遠不會被看到。

如何解決這個問題

簡單的解決方案是使該字段易變。 這將確保該字段的值是一致的,而不僅僅是最終一致的,這就是緩存可能為您執行的操作。

結論

雖然有許多類似的問題示例; 為什么我的線程沒有停止? 答案更多與Java內存模型有關,Java內存模型允許JIT“內聯”它執行硬件的字段,并在不同的緩存中具有多個數據副本。

參考: Vanilla Java博客上的JCG合作伙伴 Peter Lawrey提供的Java內存模型和優化 。

翻譯自: https://www.javacodegeeks.com/2013/01/java-memory-model-and-optimisation-2.html

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

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

相關文章

C_數組詳解

數組&#xff1a; 一 一維數組 1.1 一維數組的定義: 類型符 數組名[常量表達式]; int a[10]; 說明: 1.數組的命名規則遵循標識符命名規則。 2.定義時需要指定元素的個數。方括號里的常量表達式表示元素的個數。 3.常量表達式中不能包含變量&#xff1b;如&#xff1a;int a[n];…

CSS節選——選擇器

CSS&#xff0c;cascading style sheet&#xff0c;層疊樣式表&#xff0c;請留意層疊概念。 css3為了區分偽類和偽元素&#xff0c;偽元素采用雙冒號寫法。 常見偽類——:hover,:link,:active,:target,:not(),:focus。 常見偽元素——::first-letter,::first-line,::before…

python游戲循環設置_Pygame:游戲循環前的初始菜單

我正在制作一個this game的版本&#xff0c;并嘗試將起始菜單設置為&#xff1a;我的計劃是先做surface.fill(overlaycolor)&#xff0c;然后將這個圖像blitting到屏幕上。在一個while循環中。之后&#xff0c;在用戶想玩(另一個問題除外)之后&#xff0c;我們將進入另一個whil…

vue.js基礎知識篇(7):表單校驗詳解

目錄 網盤 第12章:表單校驗 1.npm安裝vue-validator $ npm install vue-validator 代碼示例: var Vuerequire("vue"); var VueValidatorrequire("vue-validator"); Vue.use(VueValidator); 2.直接使用script標簽引入vue.js 要下載vue-validator&#xff0c…

修改linux綁定的域名,手工修改linux系統下DA面板綁定的域名

舉例說明手工修改DA面板下虛擬主機ryan綁定的域名&#xff0c;只需要 vi /usr/local/directadmin/data/users/ryan/httpd.conf代碼如下&#xff1a;# Auto generated apache config file by DirectAdmin version 1.46.3# Modifying this file is not recommended as any change…

在JUnit測試中使用Builder模式

這并不是要成為技術含量很高的職位。 這篇文章的目的是為您提供一些指導&#xff0c;以使您的JUnit測試生活更加輕松&#xff0c;使您能夠在幾分鐘內編寫復雜的測試場景&#xff0c;并具有易于閱讀的測試優勢。 單元測試中有兩個主要部分&#xff0c;需要編寫許多引導程序代碼&…

SQL數據庫中臨時表、臨時變量和WITH AS關鍵詞創建“臨時表”的區別

原文鏈接&#xff1a;https://www.cnblogs.com/zhaowei303/articles/4204805.html SQL數據庫中數據處理時&#xff0c;有時候需要建立臨時表&#xff0c;將查詢后的結果集放到臨時表中&#xff0c;然后在針對這個數據進行操作。 創建“臨時表”&#xff08;邏輯上的臨時表&…

python 三維繪圖庫_Python第三方庫matplotlib(2D繪圖庫)入門與進階

Matplotlib一 簡介&#xff1a;Matplotlib是一個Python 2D繪圖庫&#xff0c;它可以在各種平臺上以各種硬拷貝格式和交互式環境生成出具有出版品質的圖形。 Matplotlib可用于Python腳本&#xff0c;Python和IPython shell&#xff0c;Jupyter筆記本&#xff0c;Web應用程序服務…

zbb20170626 myeclipse 2017 ci 構建 spring hibernate struts jar

轉載于:https://www.cnblogs.com/super-admin/p/7081209.html

linux處理機調度實驗報告,模擬Linux操作系統下處理機調度實驗報告

在采用多道系統的設計程序中,往往有若干進程同時處于就緒狀態。當就緒狀態進程數大于處理機數時,就必須按照某種策略來決定哪些進程優先占用處理機。本實驗模擬在單處理機情況下處理機調度處理機調度一、實驗目的&#xff1a;1、了解Linux下Emacs編輯器的使用方法&#xff0c;掌…

Java線程:保留的內存分析

本文將為您提供一個教程&#xff0c;使您可以確定活動應用程序Java線程保留Java堆空間的數量和位置。 將提供來自Oracle Weblogic 10.0生產環境的真實案例研究&#xff0c;以使您更好地理解分析過程。 我們還將嘗試證明過多的垃圾回收或Java堆空間的內存占用問題通常不是由真正…

軟件測試白皮書-等價類

設有一個檔案管理系統&#xff0c;要求用戶輸入以年月表示的日期。假設日期限定在1990年1月~2049年12月&#xff0c;并規定日期由6位數字字符組成&#xff0c;前4位表示年&#xff0c;后2位表示月。現用等價類劃分法設計測試用例&#xff0c;來測試程序的"日期檢查功能&qu…

深入css布局 (1) — 盒模型 元素分類

深入css布局&#xff08;1&#xff09;—— 盒模型 & 元素分類 “ 在css知識體系中&#xff0c;除了css選擇器&#xff0c;樣式屬性等基礎知識外&#xff0c;css布局相關的知識才是css比較核心和重要的點。今天我們來深入學習一下css布局相關的知識。” 首先來列下大綱 盒模…

批改網禁止粘貼怎么破_教育部對家長批改作業表態了,明令禁止!你怎么看?...

互聯網的發展&#xff0c;的確方便了現代人生活。視頻電話、出去買東西你都不用帶錢帶卡&#xff0c;手機一掃就可以完成支付。很多中小學的家長都會建一個家長群&#xff0c;方便老師和家長的溝通。這個群可以說是家長和學校的橋梁和紐帶&#xff0c;家長們為了支持老師的工作…

電子科大專科c語言作業1,電子科大15春《C語言(專科)》在線作業試卷.docx

電子科大 15 春《 C 語言(專科)》在線作業一、單選題(共20 道試題&#xff0c;共100 分。)1.對于 int*p;inta[];pa;的合法運算 ()a;pa;p; 相當于 a;p; 相當于 a[1];若 p 中的地址為 100 則 p; 運算后&#xff0c;則其值為 100-----------------選擇&#xff1a; C已知 intb; 則…

MapReduce算法–順序反轉

這篇文章是介紹MapReduce算法的系列文章的另一部分&#xff0c;該書在使用MapReduce進行數據密集型文本處理中找到。 先前的文章是Local Aggregation &#xff0c; Local Aggregation PartII和創建共現矩陣 。 這次我們將討論階數反轉模式。 順序反轉模式利用的MapReduce來計算…

xss防御

http://blog.csdn.net/ghsau/article/details/17027893轉載于:https://www.cnblogs.com/jiangjing/p/8076216.html

移動端頁面字體在微信被放大,導致排版錯亂

在開發微信頁面的時候&#xff0c;之前一直沒有測出這個問題。直到某天領導的手機出現了排版錯位的問題&#xff0c;拿著手機質問我的工作態度。 Google了一下發現原來微信調整了字體大小會放大網頁的字體&#xff0c;導致排版混亂。通過設置可以禁止網頁字體被放大&#xff1a…

液壓支架銷軸力學計算分析研究_基于RFID射頻精準定位的智能開采研究與應用...

一、項目背景近年來隨著智能開采技術的不斷發展&#xff0c;裝備和新工藝不斷更新換代,在智能開采中&#xff0c;對采煤機位置的精準定位是能否實現智能開采的關鍵&#xff0c;只有準確無誤地獲取煤機的準確位置&#xff0c;才能實現工作面的智能化開采&#xff0c;進而提高生產…

cf 821E Okabe and El Psy Kongroo(矩陣快速冪)

鏈接&#xff1a;http://codeforces.com/problemset/problem/821/E 分析&#xff1a;由于有邊界而且不同段邊界還不同&#xff0c;直接算是不行的。。k是1e18&#xff0c;dp也不行。。用一個16維的向量表示某一列16個位置可能的種類數&#xff0c;到下一列的轉移矩陣容易得到&a…