国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

多線程原理--學習筆記

2019-11-11 05:13:45
字體:
來源:轉載
供稿:網友

今天查看了java的Executor框架源碼,在此記錄一下,以便查閱。

(一),Executor的線程池通過ThreadPoolExecutor實現,Executors是他的工廠類,這里只說三種常用的類, ?1,Executors.newSingleThreadExecutor():線程池中只有一個線程,當線程執行結束,或因為其他原因進入DEAD狀態,則會再次創建一個線程供使用; ?2,Executors.newFixedThreadPool(nThreads):固定數量的線程池,nThreads為線程池創建時指定的線程數量,當池中線程數量不足這個數時,如果有任務,則會新建一個線程,當線程執行結束,或因為其他原因進入DEAD狀態,則會再次創建一個線程供使用; ?3,Executors.newCachedThreadPool():比較智能的線程池,理論上說,沒有線程池數限制,如果jvm或計算機運行,可以一直創建,當然這是不存在的,一般jvm都會有線程上限。當有新任務的時候,自動創建線程來執行,當線程執行完畢后,或因其他原因停止后,如果沒有allowTimeOut限制,則會自動回收(一般是60s)。

(二)ThreadPoolExecutor是通過內部類Worker類來添加線程的,Worker類是一個Runnable對象,類中自身包含有一個Thread對象,當你在運行worker的run方法時,其實他啟動的就是他本身里的Thread;

(三)說了這么多,那么多線程的原理是什么? ?要知道這個,首先要明白,線程有5個狀態:new,runable,running,block,dead;當新建一個線程的時候,就是new狀態,當線程結束了,就是dead狀態。好了,也就是說,線程活著的時候就是在:runable, running, block狀態之間;

多線程的實現,也就是多線程的復用過程,也就是說要維持線程在這三個狀態之間轉換,如何做到呢?

剛剛說到,ThreadPoolExecutor是通過worker來添加線程的,那么在worker里的runWorker方法中,他會不斷的查詢workQueue(阻塞隊列)來取任務執行。那么workQueue的數據時如何添加的呢?

這里寫一下,當新任務來的時候,線程池的工作過程: 1,當前線程數 < corePoolSize:即當前運行的線程數,小于核心線程數量,則立即創建一個線程來執行任務;

2,當前線程數 >= corePoolSize AND workQueue未滿:此時,將任務添加到workQueue里,等待處理;

3,當前線程數 >= corePoolSize AND workQueue滿了 AND 當前線程數


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 苗栗市| 吴堡县| 华亭县| 天全县| 锦州市| 尼木县| 迁西县| 色达县| 桂平市| 仪征市| 江口县| 内丘县| 新河县| 潞城市| 宜州市| 定结县| 资阳市| 上虞市| 诏安县| 玉林市| 晋中市| 政和县| 宣威市| 达孜县| 尼勒克县| 甘谷县| 方山县| 盈江县| 临江市| 炎陵县| 尚义县| 鞍山市| 阿拉善盟| 台北县| 资中县| 临沭县| 兴和县| 驻马店市| 华安县| 临湘市| 玉溪市|