java的Thread.yield,是暂停正在执行的线程,然后执行其他线程(包括被暂停的线程),但是无法保证执行yield方法的线程真正达到“让步”的目的,因为“让步”的线程也有可能被线程调度程序选中继续执行。
class MyThread extends Thread {
private String threadName;
public MyThread(String threadName) {
this.threadName = threadName;
}
@Override
public void run() {
for(int i = 0; i < 3; i++) {
System.out.println(threadName + "输出" + i + ",并让出控制权。");
Thread.yield();
}
}
}
public class ThreadYieldDemo {
public static void main(String[] args) {
MyThread t1 = new MyThread("t1");
MyThread t2 = new MyThread("t2");
t1.start();
t2.start();
}
}
第一次执行,结果如下:t2输出0,并让出控制权。
t1输出0,并让出控制权。
t1输出1,并让出控制权。
t2输出1,并让出控制权。
t2输出2,并让出控制权。
t1输出2,并让出控制权。
第二次执行,结果如下:
t1输出0,并让出控制权。
t2输出0,并让出控制权。
t1输出1,并让出控制权。
t2输出1,并让出控制权。
t1输出2,并让出控制权。
t2输出2,并让出控制权。
可见结果是变化的,有的时候线程执行yield后又再次被cpu选中继续执行。