java - volatile中i++的原子性问题
怪我咯
怪我咯 2017-04-18 10:52:11
0
3
724
/**
 * @create on 17/3/27
 * @description
 */
public class Main {
    static volatile int i = 0;
    public static class PlusTask implements Runnable{
        @Override
        public 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

怪我咯
怪我咯

走同样的路,发现不同的人生

全部回覆(3)
Peter_Zhu

你可能需要這樣:

public void run() {
            for (int k = 0; k < 10000; k++)
                synchronized (Main.class) {
                    i++;
                }
        }

或定義一個AtomicInteger

  • volatile只是起一個多執行緒快取一致性作用,並不能保證某一時刻只有一個執行緒去寫變數。

Ty80

volitile不保證原子性

刘奇

多執行緒操作共享變數問題,volitale不能不保證複合操作的原子性,也就是說後一個執行緒並不能總是看到前一個執行緒修改後的值i,解決方法加鎖,或原子操作

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板