1.调用wait()方法,线程会放弃对象锁,进入等待此对象的等待锁定池
2.sleep()方法导致了程序暂停执行指定的时间,让出cpu该其他线程, 但是他的监控状态依然保持者,当指定的时间到了又会自动恢复运行状态。 在调用sleep()方法的过程中,线程不会释放对象锁。
3.只有针对锁对象调用notify()方法后wait线程才进入对象锁定池准备获取对象锁进入运行状态。
public class YslLock {
private static Object object = new Object();
public static void main(String[] args) {
testThread();
}
private static void testThread() {
new Thread(new Runnable() {
@Override
public void run() {
synchronized (object) {
System.out.println("enter thread1...");
System.out.println("thread1 is waiting...");
try {
//调用wait()方法,线程会放弃对象锁,进入等待此对象的等待锁定池
object.wait();
} catch (Exception e) {
e.printStackTrace();
}
System.out.println("thread1 is going on ....");
System.out.println("thread1 is over!!!");
}
}
}).start();
try {
Thread.sleep(5000);
} catch (Exception e) {
e.printStackTrace();
}
new Thread(new Runnable() {
@Override
public void run() {
synchronized (object) {
System.out.println("enter thread2....");
System.out.println("thread2 is sleep....");
try {
//sleep()方法导致了程序暂停执行指定的时间,让出cpu该其他线程,
//但是他的监控状态依然保持者,当指定的时间到了又会自动恢复运行状态。
//在调用sleep()方法的过程中,线程不会释放对象锁。
Thread.sleep(5000);
} catch (Exception e) {
e.printStackTrace();
}
System.out.println("thread2 is going on....");
System.out.println("thread2 is over!!!");
//只有针对锁对象调用notify()方法后wait线程才进入对象锁定池准备获取对象锁进入运行状态。
object.notify();
}
}
}).start();
}
}
运行结果:
可以看到wait之后,第一个线程停止运行,开始运行第二个线程。当sleep时,第二个线程也停止运行了。当结束sleep,第二个线程继续运行,到结尾调用了对象锁的notify方法。然后wait的线程又开始继续运行。正好证明了上面写的三句话。
亲测:在第二个线程中,把object.notify();挪到run方法的第一行。结果也是一样的。这就说明:当持有对象锁的线程只有运行完成之后,notify才会真正的起作用。