Java線程池中線程的狀態簡介

首先明確一下線程在JVM中的各個狀態(JavaCore文件中)linux

1.死鎖,Deadlock(重點關注) 測試

2.執行中,Runnable(重點關注)   spa

3.等待資源,Waiting on condition(重點關注) 操作系統

4.等待監控器檢查資源,Waiting on monitor(eg:若是使用System.out.println等須要分配計算機資源的時候線程會如此等待,主要還需看堆棧)線程

5.暫停,Suspendedunix

6.對象等待中,Object.wait()對象

7.阻塞,Blocked(重點關注)  隊列

8.中止,Parked(此狀態必須明確,與字面意思不一樣,主要是指線程空閒時候的狀態.如在線程池中,當線程被調用使用後再次放入到池子中,則其狀態變爲了Parked)資源

Java基本線程池的實現it

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狀態的由來:只有被使用過的線程再次放入線程池中才被賦予這種狀態

相關文章
相關標籤/搜索