sleep() 和 wait() 有什么区别?
(网上的答案:sleep 是线程类(Thread)的方法,导致此线程暂停执行指定时间,给
执行机会给其他线程,但是监控状态依然保持,到时后会自动恢复。调用sleep 不会释放对
象锁。 wait 是Object 类的方法,对此对象调用wait 方法导致本线程放弃对象锁,进入等待
此对象的等待锁定池,只有针对此对象发出notify 方法(或notifyAll)后本线程才进入对象
锁定池准备获得对象锁进入运行状态。)
sleep 就是正在执行的线程主动让出cpu,cpu 去执行其他线程,在sleep 指定的时间过
后,cpu 才会回到这个线程上继续往下执行,如果当前线程进入了同步锁,sleep 方法并不会
释放锁,即使当前线程使用sleep 方法让出了cpu,但其他被同步锁挡住了的线程也无法得
到执行。wait 是指在一个已经进入了同步锁的线程内,让自己暂时让出同步锁,以便其他正
在等待此锁的线程可以得到同步锁并运行,只有其他线程调用了notify 方法(notify 并不释
放锁,只是告诉调用过wait 方法的线程可以去参与获得锁的竞争了,但不是马上得到锁,
因为锁还在别人手里,别人还没释放。如果notify 方法后面的代码还有很多,需要这些代码
执行完后才会释放锁,可以在notfiy 方法后增加一个等待和一些代码,看看效果),调用wait
方法的线程就会解除wait 状态和程序可以再次得到锁后继续向下运行。对于wait 的讲解一
定要配合例子代码来说明,才显得自己真明白。
package com.huawei.interview;
public class MultiThread {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
new Thread(new Thread1()).start();
try {
Thread.sleep(10);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
new Thread(new Thread2()).start();
}
private static class Thread1 implements Runnable
{
@Override
public void run() {
// TODO Auto-generated method stub
//由于这里的Thread1和下面的Thread2内部run方法要用同一对象作为监视器,我们这里不
能用this,因为在Thread2里面的this和这个Thread1的this不是同一个对象。我们用
MultiThread.class这个字节码对象,当前虚拟机里引用这个变量时,指向的都是同一个对
象。
synchronized (MultiThread.class) {
System.out.println("enter thread1...");
System.out.println("thread1 is waiting");
try {
//释放锁有两种方式,第一种方式是程序自然离开监视器的范围,也就是离开了
synchronized关键字管辖的代码范围,另一种方式就是在synchronized关键字管辖的代码
内部调用监视器对象的wait方法。这里,使用wait方法释放锁。
MultiThread.class.wait();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println("thread1 is going on...");
System.out.println("thread1 is being over!");
}
}
}
private static class Thread2 implements Runnable
{
@Override
public void run() {
// TODO Auto-generated method stub
synchronized (MultiThread.class) {
System.out.println("enter thread2...");
System.out.println("thread2 notify other thread can
release wait status..");
//由于notify方法并不释放锁, 即使thread2调用下面的sleep方法休息了10毫秒,但
thread1仍然不会执行,因为thread2没有释放锁,所以Thread1无法得不到锁。
MultiThread.class.notify();
System.out.println("thread2 is sleeping ten
millisecond...");
try {
Thread.sleep(10);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println("thread2 is going on...");
System.out.println("thread2 is being over!");
}
}
}
}
第1题:
9、sleep()和wait()方法都能使得线程阻塞,它们没有区别,完全一样。
第2题:
关于sleep()和wait(),以下描述错误的一项是?
A.sleep是线程类(Thread)的方法,wait是Object类的方法
B.sleep是线程类(Thread)的方法,wait是Object类的方法
C.sleep暂停线程、但监控状态仍然保持,结束后会自动恢复
D.wait后进入等待锁定池,只有针对此对象发出notify方法后获得对象锁进入运行状态
第3题:
关于sleep()和wait()方法,以下描述错误的是()。
A.sleep是线程类(Thread)的方法,wait是Object类的方法
B.sleep不释放对象锁,wait释放对象锁
C.sleep()中指定的时间是线程不会运行的最短时间,它不能保证该线程睡眠到期后就开始执行
D.wait后进入该对象的锁池,其他线程调用notify()方法并获取对象锁会进入运行状态
第4题:
关于sleep()和wait(),以下描述错误的一项是()
A.sleep是线程类(Thread)的方法,wait是Object类的方法
B.Sleep不释放对象锁,wait放弃对象锁
C.Sleep暂停线程、但监控状态任然保持,结束后会自动恢复
D.Wait后进入等待锁定池,只针对此对象发出notify方法后获取对象锁进入运行状态。
第5题:
下面能让线程停止执行的操作有()
A.sleep();
B.stop();
C.notify();
D.wait();