文章目录

  • ​​第19题- sleep&wait&join&yield区别​​
  • ​​1.两个概念​​
  • ​​1.1 锁池​​
  • ​​1.2 等待池​​
  • ​​2.比较​​

第19题- sleep&wait&join&yield区别

1.两个概念

1.1 锁池

[!NOTE]

所有需要竞争同步锁的线程都会放在锁池当中,比如当前对象的锁已经被其中一个线程得到,则其他线程需要在这个锁池进行等待,当前面的线程释放同步锁后锁池中的线程去竞争同步锁,当某个线程得到后会进入就绪队列进行等待cpu资源分配。

1.2 等待池

[!NOTE]

当我们调用wait()方法后,线程会放到等待池当中,等待池的线程是不会去竞争同步锁。只有调用​​notify()​​​或​​notifyAll()​​​后等待池的线程才会开始去竞争锁,​​notify()​​​是随机从等待池选出一个线程放 到锁池,而​​notifyAll()​​是将等待池的所有线程放到锁池当中。

2.比较

  • ​sleep()​
  • ​Thread​​的静态方法
  • 不会释放锁
  • 当前线程休眠
  • 休眠结束自动退出阻塞状态
  • 让出​​CPU​​时间片,强制进行上下文切换
  • ​wait()​
  • ​Object​​类的本地方法
  • 会释放锁
  • 和​​synchrinized​​配合使用
  • 多个线程之间进行通讯
  • 需要被唤醒
  • ​yield()​

[!NOTE]

yield()执行后线程直接进入就绪状态,马上释放了cpu的执行权,但是依然保留了cpu的执行资格, 所以有可能cpu下次进行线程调度还会让这个线程获取到执行权继续执行。

  • ​join()​

[!NOTE]

执行后线程进入阻塞状态,例如在线程B中调用线程A的join(),那线程B会进入到阻塞队 列,直到线程A结束或中断线程。