我之前在公众号里发了两篇关于线程的文章,没想到很多网友都想看,有评论说想看 sleep 与 wait 区别的,于是便有了本文。
从单词的意思上来说,两个都有使线程暂停的意思,但是实现原理以及使用的效果完全不一样。
sleep 使让线程睡眠一定的时间,不释放任何锁,但是它过了睡眠时间后,不一定能获得执行的时间!最终的调度是由CPU决定的!Thread.sleep() 是可以从任何上下文调用的静态方法。Thread.sleep() 暂停当前线程!具体可以参考我的这篇文章《代码中的Thread.sleep(0) 有什么意义?是写错了吗?》。
wait()是一个用于线程同步的实例方法。它可以在任何对象上调用,因为它定义在 java.lang.Object 上, 但只能从同步块中调用。它释放对象上的锁,以便另一个线程可以跳入并获取锁。wait 从字面上来理解的话,它具有等待的意思。它等待 notify 或 notifyAll 对其唤醒!
如果直接调用 wait 会抛出 java.lang.IllegalMonitorStateException 异常,原因是还没有得到对象锁,所以无法释放锁。
通过上面的解读,你认为 wait 可以代替 sleep 吗?
当然是替代不了的,因为最重要的一个特点就是 wait 会释放锁,而 sleep 不会释放锁!
sleep 与 wait 的区别
- sleep()线程控制自身流程。
- wait()用来线程间通信,使拥有该对象锁的线程等待直到指定时间或notify()
- wait()会释放锁和监视器,sleep()不释放任何锁或监视器等
- wait()用于线程间通信,而sleep()用于在执行时引入暂停
- 适用区域,wait只能放在同步语句块中才有意义
- sleep来自Thread类,和wait来自Object类
- sleep必须捕获异常,而wait,notify和notifyAll不需要捕获异常
- sleep是Thread的静态类方法,谁调用的谁去睡觉,即使在a线程里调用了b的sleep方法,实际上还是a去睡觉,要让b线程睡觉要在b的代码中调用sleep
- Thread.Sleep(0)的作用是“触发操作系统立刻重新进行一次CPU竞争”
- wait方法一旦过了超时时间,并不需要其他线程执行notify也能自动解除阻塞,但是如果没设置超时时间的wait方法必须等待其他线程执行notify
它们都可以被 interrupted 方法中断。在使用场景方面都可以在生产者/消费者模型中得以应用。
参考资料
- 代码中的Thread.sleep(0) 有什么意义?是写错了吗?
- synchronized 是可重入锁吗?为什么?
- 这样使用 ThreadLocal 对吗?
: » 详解sleep与wait的区别
原创文章,作者:kepupublish,如若转载,请注明出处:https://blog.ytso.com/251901.html