sleep()、wait()、join()、yield()的区别

1 、锁池

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

2、等待池

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

 

1、sleep是Thread类的静态本地方法,wait则是Object类的本地方法

2、sleep方法不会释放lock,但是wait会释放,而且会加入到等待队列中

(sleep就是把CPU的执行资格释放出去,不在运行此线程,当定时时间结束再取回CPU 的资源,参与CPU的调度,获取到CPU的资源后就可以继续运行了,而如果sleep时该线程有锁,那么sleep不会释放这个锁,而是把锁带着进入冻结状态,也就是说其他需要这个锁的线程根本不可能获取到这个锁。也就无法执行程序。如果在睡眠时其他线程调用了这个线程的interrupt方法,那么这个线程就会抛出interruptexception异常返回,这点和wait是一样的)

3、sleep方法不依赖与同步器synchronized ,但是wait需要依赖synchronized关键字

4、sleep不需要被唤醒(休眠之后推出阻塞),但是wait需要(不指定时间需要被别人打断)

5、sleep一般用于当前线程休眠,或者轮询暂停操作,wait则多用于多线程之间的通讯

6、sleep会让出CPU执行时间并强制上下文切换,而wait不一定,wait后可能还是有机会重新竞争到锁继续执行的

 

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

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

 

可用于后置通知

sleep()、wait()、join()、yield()的区别

 

上一篇:28.yield return 语法


下一篇:Generator(一)