麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

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

多線程原理--學習筆記

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 當前線程數


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 粉嫩粉嫩一区二区三区在线播放 | 成品片a免费直接观看 | 国产午夜精品久久久久久免费视 | 成人性生活视频在线观看 | 国产一级毛片高清视频 | 久久国产成人精品国产成人亚洲 | 色网站在线免费观看 | 香蕉久久久精品 | 久久久无码精品亚洲日韩按摩 | 欧美va亚洲 | 精品国产专区 | 免费a级毛片永久免费 | 免费网站看v片在线a | 亚洲日色 | 久久欧美亚洲另类专区91大神 | 免费看真人a一级毛片 | 国产午夜免费视频 | 日韩视频1| 中文字幕一区久久 | 泰剧19禁啪啪无遮挡 | 成人免费在线观看视频 | 国产精品久久久久久久久久电影 | 国产女厕一区二区三区在线视 | 久久91久久久久麻豆精品 | 国产精品久久久久一区二区 | 久久在线免费视频 | 久久午夜神器 | 中文字幕在线不卡视频 | 成人一区二区三区在线 | 成人免费看毛片 | 国产精品久久久久久久久久东京 | 毛片在线视频观看 | 91av原创| 成年免费在线视频 | 日韩视频一二区 | 欧美日韩免费一区二区三区 | 国产1区2区3区中文字幕 | 欧美人成在线视频 | 国产毛片毛片 | 国产午夜精品久久久久久久蜜臀 | 亚洲二区不卡 |