Java執行緒池中執行緒的狀態簡介

五柳-先生發表於2015-12-21

首先明確一下執行緒在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 任務。   

上述引數佇列workQueuecorePoolSize,maximumPoolSize的關係為:

如果corePoolSize中的執行緒使用完,則會使用佇列workQueue,佇列使用完才會按照maximumPoolSize的大小啟動新的執行緒

對與JavaCore檔案的生成針對不同的作業系統使用不同的指令

linux與unix 使用的指令為:jstack -l  pid >>core檔名字

IBM for aix 使用的指令為:kill -3 pid

另外根據測試情況來看.parked狀態的執行緒在linux與unix上體現不出來.只有在aix上parked狀態的執行緒才能體現出來,估計這和不同的JVM的實現有關係

parked狀態的由來:只有被使用過的執行緒再次放入執行緒池中才被賦予這種狀態

相關文章