JAVA线程之间的通信
原理
線程的通信可以被定義為:當(dāng)多個(gè)線程共同操作共享的資源時(shí),線程間通過某種方式互相告知自己的狀態(tài),以避免無(wú)效的資源爭(zhēng)奪。線程間通信的方式可以有很多種:等待-通知、共享內(nèi)存、管道流。每種方式用不同的方法來(lái)實(shí)現(xiàn),這里首先介紹等待-通知的通信方式。“等待-通知”通信方式是Java中使用普遍的線程間通信方式。
wait()方法的原理:首先,JVM會(huì)釋放當(dāng)前線程的對(duì)象鎖監(jiān)視器的Owner資格;其次,JVM會(huì)將當(dāng)前線程移入監(jiān)視器的WaitSet隊(duì)列,而這些操作都和對(duì)象鎖監(jiān)視器是相關(guān)的。所以,wait()方法必須在synchronized同步塊的內(nèi)部調(diào)用。在當(dāng)前線程執(zhí)行wait()方法前,必須通過synchronized()方法成為對(duì)象鎖的監(jiān)視器的Owner。
notify()方法的原理:JVM從對(duì)象鎖的監(jiān)視器的WaitSet隊(duì)列移動(dòng)一個(gè)線程到其EntryList隊(duì)列,這些操作都與對(duì)象鎖的監(jiān)視器有關(guān)。所以,notify()方法也必須在synchronized同步塊的內(nèi)部調(diào)用。在執(zhí)行notify()方法前,當(dāng)前線程也必須通過synchronized()方法成為對(duì)象鎖的監(jiān)視器的Owner。
筆試題
有三個(gè)線程,保證線程3在線程2前執(zhí)行,保證線程2在線程1前執(zhí)行。
解題
public class ObjectLockStudy {private static final Object lock1 = new Object();private static final Object lock2 = new Object();public static void main(String[] args) throws InterruptedException {Thread c1 = new Thread(new C1());Thread c2 = new Thread(new C2());Thread c3 = new Thread(new C3());Thread.sleep(1000);c1.start();c2.start();c3.start();}static class C1 implements Runnable {@Overridepublic void run() {synchronized (lock1) {try {lock1.wait();System.out.println(1);} catch (InterruptedException e) {e.printStackTrace();}}}}static class C2 implements Runnable {@Overridepublic void run() {try {synchronized (lock2) {lock2.wait();}System.out.println(2);synchronized (lock1) {lock1.notify();}} catch (InterruptedException e) {e.printStackTrace();}}}static class C3 implements Runnable {@Overridepublic void run() {System.out.println(3);synchronized (lock2) {lock2.notify();}}}}不難發(fā)現(xiàn),線程的啟動(dòng)順序雖然是”倒著“啟動(dòng),但執(zhí)行結(jié)果,卻是嚴(yán)格按照題目要求的。
總結(jié)
以上是生活随笔為你收集整理的JAVA线程之间的通信的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 线程池实战
- 下一篇: JAVA显式锁,各种锁分类