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

來源:互聯網
上載者:User

標籤:

首先明確一下線程在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線程池中線程的狀態簡介

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.