Thread 静态 yield 方法
当一个线程调用yield方法时,当前线程会让出CPU使用权,然后处于就绪状态,线程调度器会从线程就绪队列里面获取一个线程优先级最高的线程,当然也有可能会调度到刚刚让出CPU的那个线程来获取CPU执行权。
public class YieldTest implements Runnable {
YieldTest() {
// 创建并启动线程
Thread thread = new Thread(this);
thread.start();
}
@Override
public void run() {
// 当i=0时,让出CPU执行权,放弃时间片,进行下一轮调度
for (int i = 0; i < 5; i++) {
if ((i % 5) == 0) {
System.out.println(Thread.currentThread() + " yield cpu...");
// 当前线程让出CPU执行权,放弃时间片,进行下一轮调度
Thread.yield();
}
}
System.out.println(Thread.currentThread() + " is over!");
}
public static void main(String[] args) {
new YieldTest();
new YieldTest();
new YieldTest();
}
}
Thread[Thread-0,5,main] yield cpu...
Thread[Thread-1,5,main] yield cpu...
Thread[Thread-2,5,main] yield cpu...
Thread[Thread-1,5,main] is over!
Thread[Thread-0,5,main] is over!
Thread[Thread-2,5,main] is over!
这个执行结果不是绝对的, 线程让出CPU执行权后, 还有可能自己会抢到下一次的执行权.
sleep 与 yield 对比
- 线程调用sleep方法时调用线程会被阻塞挂起指定的时间,在这期间线程调度器不会去调度该线程。
- 调用yield方法时,线程只是让出自己剩余的时间片,并没有被阻塞挂起,而是处于就绪状态,线程调度器下一次调度时就有可能调度到当前线程执行。