先分析yield()方法,来看一个简单的例子
public class ThreadYieldTest {
public static void main(String[] args) {
// 启动三个线程
new YieldThread("李白").start();
new YieldThread("香炉").start();
}
}
public class YieldThread extends Thread {
public YieldThread(String name) {
super(name);
}
@Override
public void run() {
for (int i = 1; i <= 40; i++) {
System.out.println(Thread.currentThread().getName() + "------" + i);
if (i == 20) {
Thread.yield();
}
}
}
}
上面这个线程作用是输出1到40的整数,当输出到第20个数时,会执行线程让步Thread.yield();
这个时候通过观察控制台的输出语句就能很好的理解yield()方法的作用了!
情况1:香炉先运行到输出第20个数,此时香炉执行了yield()方法,也即线程让步,于是乎李白抢到了CPU的执行权。开始执行李白这条线程。
情况2:李白先运行到输出第20个数,此时李白执行了yield()方法,但是李白在让步了以后又抢到了CPU的执行权,所以李白继续使用并往下输出了21!(这个情况试了好多次才出来!)
结合网上对yield()方法的说明得出结论:
yield()方法让执行该方法的线程放弃当前对CPU的执行权,并让所有线程开始抢夺CPU的执行权。此时每一条优先级最高的线程都有可能抢到CPU的执行权,包括刚刚放弃了执行权的线程!