Java執行緒池中執行緒的狀態簡介
首先明確一下執行緒在JVM中的各個狀態(JavaCore檔案中)
1.死鎖,Deadlock(重點關注)
2.執行中,Runnable(重點關注)
3.等待資源,Waiting on condition(重點關注)
4.等待監控器檢查資源,Waiting on monitor(eg:如果使用System.out.println等需要分配計算機資源的時候執行緒會如此等待,主要還需看堆疊)
5.暫停,Suspended
6.物件等待中,Object.wait()
7.阻塞,Blocked(重點關注)
8.停止,Parked(此狀態必須明確,與字面意思不同,主要是指執行緒空閒時候的狀態.如線上程池中,當執行緒被呼叫使用後再次放入到池子中,則其狀態變為了Parked)
Java基本執行緒池的實現
public ThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, BlockingQueue<Runnable> workQueue)
引數詳解如下:
corePoolSize - 池中所儲存的執行緒數,包括空閒執行緒.(核心執行緒)
maximumPoolSize - 池中允許的最大執行緒數。
keepAliveTime - 當執行緒數大於核心時,此為終止前多餘的空閒
執行緒等待新任務的最長時間。
unit - keepAliveTime 引數的時間單位。
workQueue - 執行前用於保持任務的佇列。此佇列僅保持由 execute
方法提交的 Runnable 任務。
上述引數佇列workQueue與corePoolSize,maximumPoolSize的關係為:
如果corePoolSize中的執行緒使用完,則會使用佇列workQueue,佇列使用完才會按照maximumPoolSize的大小啟動新的執行緒
對與JavaCore檔案的生成針對不同的作業系統使用不同的指令
linux與unix 使用的指令為:jstack -l pid >>core檔名字
IBM for aix 使用的指令為:kill -3 pid
另外根據測試情況來看.parked狀態的執行緒在linux與unix上體現不出來.只有在aix上parked狀態的執行緒才能體現出來,估計這和不同的JVM的實現有關係
parked狀態的由來:只有被使用過的執行緒再次放入執行緒池中才被賦予這種狀態
相關文章
- Java多執行緒-執行緒狀態Java執行緒
- Java執行緒的狀態Java執行緒
- Java 執行緒池中的執行緒複用是如何實現的?Java執行緒
- Java 執行緒池獲取池中所有執行緒列表的方法Java執行緒
- 玩轉java多執行緒 之多執行緒基礎 執行緒狀態 及執行緒停止實戰Java執行緒
- 執行緒狀態執行緒
- Java執行緒池中的execute和submitJava執行緒MIT
- 執行緒池中多餘的執行緒是如何回收的?執行緒
- Java執行緒狀態轉換Java執行緒
- 【Java】執行緒的 6 種狀態Java執行緒
- Java 執行緒的5種狀態Java執行緒
- java執行緒的狀態+鎖分析Java執行緒
- 執行緒簡介執行緒
- 多執行緒的執行緒狀態及相關操作執行緒
- 【Java】【多執行緒】執行緒池簡述Java執行緒
- Java執行緒狀態及切換Java執行緒
- Java執行緒狀態及同步鎖Java執行緒
- 【JAVA併發第二篇】Java執行緒的建立與執行,執行緒狀態與常用方法Java執行緒
- 執行緒池中的最大執行緒數、核心執行緒數和佇列大小的合理設定執行緒佇列
- java的執行緒、建立執行緒的 3 種方式、靜態代理模式、Lambda表示式簡化執行緒Java執行緒模式
- Java多執行緒(04)執行緒狀態與上線文切換以及Thread方法介紹Java執行緒thread
- 詳解Java執行緒池的ctl(執行緒池控制狀態)【原始碼分析】Java執行緒原始碼
- ThreadPollExcutor執行緒池的狀態thread執行緒
- 執行緒狀態和鎖執行緒
- JAVA 執行緒狀態及轉化(轉)Java執行緒
- 深入理解Java多執行緒與併發框(第①篇)——執行緒的狀態Java執行緒
- 詳解 JUC 執行緒池中的 ThreadPoolExecutor執行緒thread
- JavaSE_多執行緒入門 執行緒安全 死鎖 狀態 通訊 執行緒池Java執行緒
- Java併發程式設計之執行緒篇之執行緒簡介(二)Java程式設計執行緒
- 乾貨:教你如何監控 Java 執行緒池執行狀態Java執行緒
- Java多執行緒-執行緒中止Java執行緒
- 程式和執行緒簡介執行緒
- 程式設計規範-父子執行緒必須放在不同的執行緒池中程式設計執行緒
- 【多執行緒與高併發】- 執行緒基礎與狀態執行緒
- Java執行緒篇——執行緒的開啟Java執行緒
- 【Java多執行緒】執行緒安全的集合Java執行緒
- Java多執行緒-執行緒池的使用Java執行緒
- MySQL執行緒狀態詳解MySql執行緒
- jstack判斷執行緒狀態JS執行緒