线程:等待/通知机制
生活随笔
收集整理的這篇文章主要介紹了
线程:等待/通知机制
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
? 方法wait()
? ?方法wait()的作用是使當前執行代碼的線程進行等待, wait()被執行后,鎖被自動釋放。wait()方法是Object類的方法,該方法用來將當前線程置入"預執行隊列"中,并且在wait()所在的代碼處停止執行,直到接到通知或被中斷為止。
? ?方法notify()
? ?在執行完notify()方法后,當前線程不會馬上釋放該對象鎖,呈wait狀態的線程也并不能馬上獲取該對象鎖,要等到執行notify()方法的線程將程序執行完,也就是退出synchronized代碼塊后,當前線程才會釋放鎖,而呈wait狀態所在的線程才可以獲取該對象鎖。
? ?notify()方法一次只隨機通知一個線程進行喚醒。
? ?notifyAll()方法喚醒所有線程。
wait(long)方法
? ?帶一個參數的wait(long)方法的功能是等待某一時間是否有線程對鎖進行喚醒,如果超過這個時間則自動喚醒。
public class Run {static private Object lock = new Object();static private Runnable runable1 = new Runnable(){@Overridepublic void run() {synchronized(lock){try {System.out.println("wait begin timer" + System.currentTimeMillis());lock.wait(5000);System.out.println("wait end timer" + System.currentTimeMillis());} catch (InterruptedException e) {e.printStackTrace();}}}};public static void main(String[] args){Thread t = new Thread(runable1);t.start();} }??
?
當interrupt方法遇到wait方法
? 當線程呈wait狀態時, 調用線程對象的interrupt()方法會出現InterruptedException異常.
public class Service {public void testMethod(Object lock){try{synchronized(lock){System.out.println("begin wait...");lock.wait();//Thread.sleep(10000);System.out.println(" end wait...");}}catch(InterruptedException e){e.printStackTrace();System.out.println("出現異常了,因為呈wait狀態的線程被interrupt了 !");}} }public class ThreadA extends Thread{private Object lock;public ThreadA(Object lock){this.lock = lock;}@Overridepublic void run(){Service service = new Service();service.testMethod(lock);} }public class Test {public static void main(String[] args){try{Object lock = new Object();ThreadA a = new ThreadA(lock);a.start();Thread.sleep(5000);a.interrupt();}catch(InterruptedException e){e.printStackTrace();}} }通過管道進行線程間通信: 字節流,字符流
? 在jdk中, 提供了4個類來使線程間可以進行通信:?
? ?1). PipedInputStream 和 PipedOutputStream ?處理字節流
? ?2). PipedReader和PipedWriter ?處理字符流
總結
以上是生活随笔為你收集整理的线程:等待/通知机制的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 线程:volatile关键字
- 下一篇: 线程:方法join的使用