为了练习生锈的 Java,我想尝试一个简单的多线程共享数据示例,但遇到了令我惊讶的事情。
基本上,我们AtomicInteger
在三个线程之间有一个共享计数器,每个线程轮流递增和打印计数器。
主要的
AtomicInteger counter = new AtomicInteger(0);
CounterThread ct1 = new CounterThread(counter, "A");
CounterThread ct2 = new CounterThread(counter, "B");
CounterThread ct3 = new CounterThread(counter, "C");
ct1.start();
ct2.start();
ct3.start();
反线程
public class CounterThread extends Thread
{
private AtomicInteger _count;
private String _id;
public CounterThread(AtomicInteger count, String id)
{
_count = count;
_id = id;
}
public void run()
{
while(_count.get() < 1000)
{
System.out.println(_id + ": " + _count.incrementAndGet());
Thread.yield();
}
}
}
我希望当每个线程执行Thread.yield()
时,它会将执行权交给另一个线程以_count
像这样递增:
A: 1
B: 2
C: 3
A: 4
...
相反,我得到了A
将增加_count
100 倍的输出,然后将其传递给B
. 有时所有三个线程会一致地轮流,但有时一个线程会主导几个增量。
为什么不Thread.yield()
总是将处理交给另一个线程?