JAVA多线程--Thinking in java
聊聊并發(fā):http://ifeve.com/java-concurrency-thread-directory/
?
阻塞狀態(tài):
sleep ?可中斷利用 interrupt方法
wait
IO ?不可中斷 ? I:關(guān)閉底層資源 ?II:new I O
任務(wù)試圖在某個(gè)對(duì)象上調(diào)用其同步控制方法,但是對(duì)象鎖被另一個(gè)任務(wù)獲取 ?syn不可中斷 ? lock.lockInterruptibly() ?可以中斷
Executor.shutdownNow() 發(fā)送一個(gè)interrupt() 調(diào)用給它啟動(dòng)的所有線程?
如何中斷單一任務(wù)?
Executor.submit()啟動(dòng)單一任務(wù) 該方法返回一個(gè)Futrue<?> 類型的參數(shù)
利用這個(gè)參數(shù)的cancel(true)即相當(dāng)于在該線程上調(diào)用interrupt()?
public static void main(String[]args){final Test st = new Test();new Thread(){@Overridepublic void run(){st.f1(100);}}.start();System.out.println("main is over");} }
剛才寫測(cè)試用例 突然發(fā)現(xiàn)自己對(duì)有些概念不是特別明確 比如上面的例子 ?
我原以為 main線程輸出完那句話 整個(gè)程序就結(jié)束了 其實(shí)并非這樣
只有當(dāng)把副線程設(shè)置為守護(hù)線程的時(shí)候 才是我想象的那樣
?
如果在線程上調(diào)用interrupt方法停止某個(gè)任務(wù) 那么在run循環(huán)碰巧沒(méi)有產(chǎn)生任何阻塞的情況下 任務(wù)無(wú)法中斷?
1可以調(diào)用interrupted檢查中斷狀態(tài) ?while(!Thread.interrupted())
wait方法
I帶毫秒數(shù),在wait期間對(duì)象鎖是釋放的 可以通過(guò)notify notifyall釋放 或者時(shí)間到期 從wait中恢復(fù)?
II不帶參數(shù) wait無(wú)限期等待下去
調(diào)用wait notify notifyall 的方法必須在同步控制方法或者同步控制塊里
死鎖的四個(gè)條件:
1互斥條件。任務(wù)使用的資源至少有一個(gè)是不能共享的
2至少有一個(gè)任務(wù)它必須持有一個(gè)資源且正在等待獲取一個(gè)當(dāng)前被別的任務(wù)持有的資源。
3資源不能被任務(wù)搶占
4必須有循環(huán)等待
?
轉(zhuǎn)載于:https://www.cnblogs.com/luyu1993/p/6985788.html
總結(jié)
以上是生活随笔為你收集整理的JAVA多线程--Thinking in java的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 算法导轮之B树的学习
- 下一篇: 第二阶段冲刺02