国产探花免费观看_亚洲丰满少妇自慰呻吟_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 當前線程數


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 正宁县| 体育| 安康市| 台前县| 台江县| 海伦市| 普格县| 名山县| 从化市| 贞丰县| 禹州市| 阜新市| 大庆市| 庄河市| 舞阳县| 汉阴县| 乳山市| 平遥县| 介休市| 都江堰市| 洞头县| 丽水市| 措勤县| 美姑县| 景东| 雷波县| 望江县| 新闻| 绥江县| 杂多县| 团风县| 虹口区| 吴忠市| 东乌珠穆沁旗| 锡林郭勒盟| 偏关县| 化隆| 黔南| 绵阳市| 谢通门县| 宁乡县|