Java volatile變量無法正常運行。
誰能解釋為什么它在這里不起作用?由于我被聲明為volatile,因此應該保護它免受內(nèi)存不一致的影響。
它受到保護,但不幸的i++是不是原子操作。它實際上是讀取/遞增/存儲。因此,volatile這不會使您擺脫線程之間的競爭狀況。您可能會從程序中獲得以下操作順序:
線程#1讀取i,得到10之后,線程#2讀取i,得到10#1線程i增加到11線程#2遞增i到11線程#1將11存儲到 i線程2將11存儲到 i如您所見,即使發(fā)生了2個增量,并且線程之間的值已正確同步,競爭條件也意味著該值僅增加了1。請看此美觀的說明。這是另一個很好的答案:Java線程中的volatileint是安全的嗎?
您應該使用的是AtomicInteger允許您從多個線程安全地遞增的內(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); }}
由于易失性構建發(fā)生在關系之前,因此i的最終值應嚴格為2000000。但是,實際結果與變量i不具有易失性沒有什么不同。誰能解釋為什么它在這里不起作用?由于我被聲明為volatile,因此應該保護它免受內(nèi)存不一致的影響。
相關文章:
1. Docker for Mac 創(chuàng)建的dnsmasq容器連不上/不工作的問題2. 關docker hub上有些鏡像的tag被標記““This image has vulnerabilities””3. 我何時應該在Java中使用JFrame.add(component)和JFrame.getContentPane()。add(component)4. docker - 如何修改運行中容器的配置5. docker鏡像push報錯6. html5和Flash對抗是什么情況?7. javascript - 請指條明路,angular的$event,在select中卻是undefined?8. 利用IPMI遠程安裝centos報錯!9. javascript - 在 model里定義的 引用表模型時,model為undefined。10. phpstudy8.1沒集成mysql-front

網(wǎng)公網(wǎng)安備