狀態1:新建一個線程并且開啟start()方法,使Java線程和操作系統線程聯系起來;
狀態2:Running——Waiting :調用wait方法
1
2
3
4
5
6
7
|
synchronized (lock){ lock.wait(); //進入waiting狀態,釋放鎖 } synchronized (lock){ lock.notifyAll(); //,喚醒所有線程,使所有在waiting狀態的線程進入blocked狀態,進入entry List隊列和其他線程一起競爭鎖 } |
狀態3Running——Waiting:調用join()方法 join()方法最終調用的也是wait方法,它使用了保護性暫停機制:當兩個線程之間有關系時,比如一個線程需要等待另外一個線程的結果,t.join()所有其他的線程都必須等待t線程執行完了才能執行
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
public final void join() throws InterruptedException { join( 0 ); } public final synchronized void join( long millis) throws InterruptedException { long base = System.currentTimeMillis(); long now = 0 ; if (millis < 0 ) { throw new IllegalArgumentException( "timeout value is negative" ); //判斷是否超時 } if (millis == 0 ) { while (isAlive()) { //判斷線程是否活著,如果 wait( 0 ); } } else { while (isAlive()) { long delay = millis - now; if (delay <= 0 ) { break ; } wait(delay); now = System.currentTimeMillis() - base; } } } |
park(t) unpark(t) 可以指定需要喚醒的線程,每一個線程都有一個parker對象 包含counter mutex 當線程調用 大致是下面這個意思
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
park(t){ if (t.ounter == 0 ) t.wait; else if (t.counter == 1 ) counter = 0 ; } unpark(t){ if (t.counter == 1 ) } e;se if (t.counter == 0 ){ t.counter = 0 ; 喚醒t線程 } |
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。
原文鏈接:https://www.cnblogs.com/guosai1500581464/p/13393796.html