私は AtomicInteger と、その操作がアトミックである方法と、これらのプロパティがマルチスレッドにどのように役立つかについて読んでいました。
同じことをテストするために、次のプログラムを作成しました。
各スレッドは 500 回ループし、スレッドが getNext() を呼び出すたびに一意の番号を取得する必要があるため、セットの最終的なサイズは 1000 になるはずです。
しかし、出力は常に 1000 未満です。ここで何が欠けていますか?
public class Sequencer {
private final AtomicInteger i = new AtomicInteger(0);
public int getNext(){
return i.incrementAndGet();
}
public static void main(String[] args) {
final Sequencer seq = new Sequencer();
final Set<Integer> set = new HashSet<Integer>();
Thread t1 = new Thread(new Runnable() {
@Override
public void run() {
for (int i=0; i<500; i++)
set.add(seq.getNext());
}
},"T1");
t1.start();
Thread t2 = new Thread(new Runnable() {
@Override
public void run() {
for (int i=0; i<500; i++)
set.add(seq.getNext());
}
},"T2");
t2.start();
try {
t1.join();
t2.join();
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(set.size());
}
}