一建报名时间2023/搜索引擎技术优化
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() {@Overridepublic 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() {@Overridepublic 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才会真正的起作用。