久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術(shù)文章
文章詳情頁

Java volatile變量無法正常運(yùn)行。

瀏覽:151日期:2024-04-27 15:05:44
如何解決Java volatile變量無法正常運(yùn)行。?

誰能解釋為什么它在這里不起作用?由于我被聲明為volatile,因此應(yīng)該保護(hù)它免受內(nèi)存不一致的影響。

它受到保護(hù),但不幸的i++是不是原子操作。它實(shí)際上是讀取/遞增/存儲。因此,volatile這不會(huì)使您擺脫線程之間的競爭狀況。您可能會(huì)從程序中獲得以下操作順序:

線程#1讀取i,得到10之后,線程#2讀取i,得到10#1線程i增加到11線程#2遞增i到11線程#1將11存儲到 i線程2將11存儲到 i

如您所見,即使發(fā)生了2個(gè)增量,并且線程之間的值已正確同步,競爭條件也意味著該值僅增加了1。請看此美觀的說明。這是另一個(gè)很好的答案:Java線程中的volatileint是安全的嗎?

您應(yīng)該使用的是AtomicInteger允許您從多個(gè)線程安全地遞增的內(nèi)容。

static final AtomicInteger i = new AtomicInteger(0);...for (int j = 0; j<1000000; j++) { i.incrementAndGet();}解決方法

public class MyThread {volatile static int i;

public static class myT extends Thread {public void run (){ int j = 0; while(j<1000000){i++;j++; }} } public static void main (String[] argv) throws InterruptedException{ i = 0; Thread my1 = new myT(); Thread my2 = new myT(); my1.start(); my2.start(); my1.join(); my2.join(); System.out.println('i = '+i); }}

由于易失性構(gòu)建發(fā)生在關(guān)系之前,因此i的最終值應(yīng)嚴(yán)格為2000000。但是,實(shí)際結(jié)果與變量i不具有易失性沒有什么不同。誰能解釋為什么它在這里不起作用?由于我被聲明為volatile,因此應(yīng)該保護(hù)它免受內(nèi)存不一致的影響。

標(biāo)簽: java
相關(guān)文章:
主站蜘蛛池模板: 广元市| 当雄县| 枝江市| 梁山县| 江源县| 平潭县| 仁怀市| 东兰县| 禹城市| 涟水县| 静安区| 葵青区| 泽库县| 苏尼特左旗| 龙里县| 收藏| 公安县| 新龙县| 乳源| 内丘县| 晋江市| 龙游县| 白玉县| 信宜市| 攀枝花市| 本溪| 镇安县| 正安县| 新余市| 安远县| 朝阳县| 陈巴尔虎旗| 齐齐哈尔市| 洪洞县| 运城市| 英德市| 历史| 红安县| 九龙城区| 壤塘县| 莫力|