yiled()方法的作用是放弃当前CPU的资源,将资源让给其它线程,但放弃的时间不确定,有可能刚刚放弃,又马上获得了CPU时间片。下面看一个小例子,看一下具体效果。 public static void main(String[] args) throws InterruptedException {
MyThread t = new MyThread();
t.start();
Thread.sleep(2);
for (int i = 0; i < 9000; i++) {
System.out.println("i=" + i);
}
}
public static class MyThread extends Thread {
private long beginTime = System.currentTimeMillis();
private int count = 0;
@Override
public void run() {
super.run();
for (int i = 0; i < 1000; i++) {
yield();
count = count + (i + 1);
System.out.println("count=" + count);
}
long endTime = System.currentTimeMillis();
System.out.println("用时:" + (endTime - beginTime) + "毫秒");
}
}
看一下运行结果:
![](https://images2015.cnblogs.com/blog/913716/201606/913716-20160627134600640-1858532436.png)
前三段是第一次运行的结果,可以看出来主线程和子线程是交替出现的,count是子线程打印的结果,i是主线程打印的结果。第四段和第五段分别是我第二次和第三次运行的结果,可以看出子线程运行的时间是不一样的,也就是子线程让出cpu的时间是不固定的。