侧边栏壁纸
博主头像
逆流者

不登高山,不知天之高也;不临深溪,不知地之厚也。

  • 累计撰写 147 篇文章
  • 累计创建 43 个标签
  • 累计收到 4 条评论
隐藏侧边栏

Java并发编程(六)让出CPU执行权的 yield方法

逆流者
2021-02-21 / 0 评论 / 0 点赞 / 171 阅读 / 1,234 字 / 正在检测是否收录...
温馨提示:
本文最后更新于2021-02-21,若内容或图片失效,请留言反馈。 部分素材来自网络,若不小心影响到您的利益,请联系我们删除。

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方法时,线程只是让出自己剩余的时间片,并没有被阻塞挂起,而是处于就绪状态,线程调度器下一次调度时就有可能调度到当前线程执行。
0

评论