yield与park的区别

  1. yield表示放弃本次cpu的时间片,但是操作系统在下一个时间片依旧可能会调用该线程/进程

  2. park表示线程/进程睡眠,需要让其他线程/进程唤醒,才有可能重新被操作系统分配时间片,

  3. 非自旋锁,底层一般采用park来实现,如果用yield,在锁竞争激烈的情况下,一个线程可能一直处在 获得cpu时间片 -> 获取锁失败 -> 放弃时间片这样的循环中,线程上线文的切换频繁,浪费cpu; 所以每个锁都会有一个等待队列,线程获取锁失败后,就将自己加入等待队列中,当别的线程释放锁后,会从等待队列中挑选一个线程唤醒

posted @ 2020-02-04 14:24  xsirfly  阅读(357)  评论(0编辑  收藏  举报