java - volatile中i++的原子性问题
怪我咯
怪我咯 2017-04-18 10:52:11
0
3
721
/**
 * @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

これが必要になる場合があります:

リーリー

または定義するAtomicInteger

  • volatile は、マルチスレッド キャッシュの整合性としてのみ機能し、特定の時点で 1 つのスレッドのみが変数を書き込むことを保証しません。

いいねを押す +0
Ty80

volitile は原子性を保証しません

いいねを押す +0
刘奇

共有変数のマルチスレッド操作の問題。Volitale は複合操作のアトミック性を保証できません。つまり、後者のスレッドは前のスレッドの変更された値 i を常に参照できるわけではありません。解決策は、ロックするかアトミックに操作することです。

いいねを押す +0
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート