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选中继续执行。