背景
面试过程中会被问到:sleep和wait方法有啥区别,今天就总结一下
简述
sleep 方法和 wait 方法都是用来将线程进入休眠状态的,并且 sleep 和 wait 方法都可以响应 interrupt 中断,也就是线程在休眠的过程中,如果收到中断信号,都可以进行响应并中断,且都可以抛出 InterruptedException 异常,那 sleep 和 wait 有什么区别呢?接下来,我们一起来看。
区别 一、所属的类不同:
wait 方法属于 Object 类的方法,而 sleep 属于 Thread 类的方法,如下图所示:
区别二、语法使用不同
wait 方法必须配合 synchronized 一起使用,不然在运行时就会抛出 IllegalMonitorStateException 的异常,如下代码所示:
public static void main(String[] args) throws InterruptedException {
Object lock = new Object();
new Thread(() -> {
try {
System.out.println( "wait之前");//调用wait 方法
lock.wait();
System.out.println( "wait 之后");}catch (InterruptedException e) {
e.printStackTrace();
}
}).start();
Thread.sleep( 100);
System.out.println("执行notify ");//调用notify 方法
lock.notify();
}
执行结果:
而 sleep 可以单独使用,无需配合 synchronized 一起使用。
区别三:唤醒方式不同
sleep 方法必须要传递一个超时时间的参数,且过了超时时间之后,线程会自动唤醒。而 wait 方法可以不传递任何参数,不传递任何参数时表示永久休眠,直到另一个线程调用了 notify 或 notifyAll 之后,休眠的线程才能被唤醒。也就是说 sleep 方法具有主动唤醒功能,而不传递任何参数的 wait 方法只能被动的被唤醒。
区别四:释放锁资源不同
wait 方法会主动的释放锁,而 sleep 方法则不会。
区别四:释放锁资源不同
wait 方法会主动的释放锁,而 sleep 方法则不会。
区别五:线程进入状态不同
调用 sleep 方法线程会进入 TIMED_WAITING 有时限等待状态,而调用无参数的 wait 方法,线程会进入 WAITING 无时限等待状态。
其他常见问题
为什么wait要定义在Object中,而不定义在Thread中?
在同步代码块中,我们说需要一个对象锁来实现多线程的互斥效果,也就是说,Java的锁是对象级别的,而不是线程级别的。
为什么wait必须写在同步代码块中?
原因是避免CPU切换到其他线程,而其他线程又提前执行了notify方法,那这样就达不到我们的预期(先wait再由其他线程来唤醒),所以需要一个同步锁来保护