线程让步和sleep方法不一样,调用sleep方法之后,线程是进入阻塞状态,而调用yield方法,线程是回到就绪状态,处理器重新分配执行权。只有其他处理器的优先级大于或者等于让步的线程,其才能得到执行的权限。完全可能的是当前线程调用让步方法之后,他还能得到处理器执行的权限,比如没有其他线程的优先级比他高,下面的代码演示了这一点。
class YieldThread extends Thread
{
String name;
public YieldThread(String name) {
super(name);
}
@Override
public void run() {
for(int i=0;i<100;i++)
{
if(i==20)
{
//线程让步,并不是阻塞,而是让处理器重新调度,只有其他线程优先级大于等于当前
//线程时,才能被分配到执行机会,完全有可能当前线程又继续执行
Thread.yield();
}
System.out.println(this.getName()+" "+i);
}
}
}
public class TestYield {
public static void main(String[] args) {
YieldThread y1= new YieldThread("高级");
y1.setPriority(Thread.MAX_PRIORITY);
y1.start();
YieldThread y2= new YieldThread("低级");
y2.setPriority(Thread.MIN_PRIORITY);
y2.start();
}
}
通过运行结果可以看到当输出20之后,高级线程调用让步方法之后,处理器的执行权还是在他手上的,所以这个让权,让出去的时候也得看对方有没有本事接权,如果没有本事接权的话,那只好俺继续掌权了,哈哈。