/**
* @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
天蓬老师2017-04-18 10:54:11
これが必要になる場合があります:
リーリーまたは定義するAtomicInteger
volatile は、マルチスレッド キャッシュの整合性としてのみ機能し、特定の時点で 1 つのスレッドのみが変数を書き込むことを保証しません。
怪我咯2017-04-18 10:54:11
共有変数のマルチスレッド操作の問題。Volitale は複合操作のアトミック性を保証できません。つまり、後者のスレッドは前のスレッドの変更された値 i を常に参照できるわけではありません。解決策は、ロックするかアトミックに操作することです。