java - volatile中i++的原子性問題
問題描述
/** * @create on 17/3/27 * @description */public class Main { static volatile int i = 0; public static class PlusTask implements Runnable{@Overridepublic void run(){ for(int k=0; k<10000; k++)i++;} } public static void main(String[] args) throws InterruptedException{Thread[] threads = new Thread[10];for(int i=0;i<10;i++){ threads[i] = new Thread(new PlusTask()); threads[i].start();}for(int i=0;i<10;i++){ threads[i].join();}System.out.println(i); }}
請教各位大牛 為什么這里的輸出總是小于10000? 已經調用了thread.join
問題解答
回答1:你可能需要這樣:
public void run() { for (int k = 0; k < 10000; k++)synchronized (Main.class) { i++;}}
或者定義一個AtomicInteger
volatile只是起一個多線程緩存一致性作用,并不能保證某時刻只有一個線程去寫變量。
回答2:volitile不保證原子性
回答3:多線程操作共享變量問題,volitale不能不保證復合操作的原子性,也就是說后一個線程并不能總是看到前一個線程修改后的值i,解決方法加鎖,或者原子操作
相關文章:
1. 測試自動化html元素選擇器元素ID或DataAttribute [關閉]2. html5 - datatables 加載不出來數據。3. javascript - QQ第三方登錄的問題4. html5和Flash對抗是什么情況?5. 利用IPMI遠程安裝centos報錯!6. node.js - mongodb查找子對象的名稱為某個值的對象的方法7. 運行python程序時出現“應用程序發生異常”的內存錯誤?8. 在mac下出現了兩個docker環境9. 正在使用electron和node.js做桌面應用,需要實時監聽是否有網絡連接,node或者electron是否可以做到10. spring-mvc - spring-session-redis HttpSessionListener失效

網公網安備