簡(jiǎn)單記錄線程池和線程的關(guān)閉

發(fā)現(xiàn)網(wǎng)上很少有關(guān)于線程關(guān)閉的文檔,正好也在看這個(gè)東西,現(xiàn)在來做個(gè)簡(jiǎn)單的記錄

線程池的關(guān)閉

首先看線程池ThreadPoolExecutor的關(guān)閉方法
線程池的關(guān)閉主要有兩個(gè)方法:shutdown和shutdownNow兩個(gè),但是兩個(gè)方法還是有很大的區(qū)別的
shutdown:官方給出的解釋是“按過去執(zhí)行已提交任務(wù)的順序發(fā)起一個(gè)有序的關(guān)閉,但是不接受新任務(wù)”,也就是說執(zhí)行這個(gè)方法的時(shí)候線程池并不是立即關(guān)閉,而是還會(huì)把已經(jīng)有的線程執(zhí)行完畢,只不過不會(huì)再接受新的任務(wù)。
shutdownNow:官方給出的解釋是“嘗試停止所有的活動(dòng)執(zhí)行任務(wù)、暫停等待任務(wù)的處理,并返回等待執(zhí)行的任務(wù)列表,嘗試停止所有的活動(dòng)執(zhí)行任務(wù)、暫停等待任務(wù)的處理,并返回等待執(zhí)行的任務(wù)列表。在從此方法返回的任務(wù)隊(duì)列中排空(移除)這些任務(wù)。并不保證能夠停止正在處理的活動(dòng)執(zhí)行任務(wù),但是會(huì)盡力嘗試。 此實(shí)現(xiàn)通過 Thread.interrupt()

取消任務(wù),所以無法響應(yīng)中斷的任何任務(wù)可能永遠(yuǎn)無法終止。”,注意措辭是嘗試,也就是說也不一定能立即關(guān)閉,那么我們現(xiàn)在來看源代碼

再往底層我們先不管,下邊我們來看interrupt官方給出的解釋,

如果當(dāng)前線程沒有中斷它自己(這在任何情況下都是允許的),則該線程的 checkAccess 方法就會(huì)被調(diào)用,這可能拋出 SecurityException。

如果線程在調(diào)用 Object 類的 wait()、wait(long) 或 wait(long, int) 方法,或者該類的 join()、join(long)、join(long, int)、sleep(long) 或 sleep(long, int) 方法過程中受阻,則其中斷狀態(tài)將被清除,它還將收到一個(gè) InterruptedException。

如果該線程在可中斷的通道上的 I/O 操作中受阻,則該通道將被關(guān)閉,該線程的中斷狀態(tài)將被設(shè)置并且該線程將收到一個(gè) ClosedByInterruptException。

如果該線程在一個(gè) Selector 中受阻,則該線程的中斷狀態(tài)將被設(shè)置,它將立即從選擇操作返回,并可能帶有一個(gè)非零值,就好像調(diào)用了選擇器的 wakeup 方法一樣。

如果以前的條件都沒有保存,則該線程的中斷狀態(tài)將被設(shè)置。

中斷一個(gè)不處于活動(dòng)狀態(tài)的線程不需要任何作用。

相信看到這里我們就已經(jīng)了解了。

線程的關(guān)閉

線程的關(guān)閉sun給出了好多的方法,有stop、suspended、interrupt,前面的兩種已經(jīng)被設(shè)置為過時(shí),所以本人覺得最有可能用到的只有interrupt方法,而interrupt方法,上邊已經(jīng)給出了解釋。

但是我沒有看到能夠立即停止線程的一個(gè)方法,不知道是怎么回事,如果有人知道請(qǐng)不吝賜教一下,非常感謝!

通過翻閱《并發(fā)編程的藝術(shù)》,又找到了一種方法,通過設(shè)置標(biāo)志位來結(jié)束,但是這種方法得是在一些合適的場(chǎng)合才行,比如在run方法中有while(ture)方法,我們可以通過設(shè)置標(biāo)志位,來破壞這個(gè)條件來達(dá)到優(yōu)雅的終止線程的方法,因?yàn)檫@種方式能夠使線程在終止時(shí)有機(jī)會(huì)去清理資源。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 第三章 Java內(nèi)存模型 3.1 Java內(nèi)存模型的基礎(chǔ) 通信在共享內(nèi)存的模型里,通過寫-讀內(nèi)存中的公共狀態(tài)進(jìn)行隱...
    澤毛閱讀 4,502評(píng)論 2 21
  • 一、并發(fā) 進(jìn)程:每個(gè)進(jìn)程都擁有自己的一套變量 線程:線程之間共享數(shù)據(jù) 1.線程 Java中為多線程任務(wù)提供了很多的...
    SeanMa閱讀 2,807評(píng)論 0 11
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,554評(píng)論 19 139
  • 一、進(jìn)程和線程 進(jìn)程 進(jìn)程就是一個(gè)執(zhí)行中的程序?qū)嵗?,每個(gè)進(jìn)程都有自己獨(dú)立的一塊內(nèi)存空間,一個(gè)進(jìn)程中可以有多個(gè)線程。...
    阿敏其人閱讀 2,702評(píng)論 0 13
  • layout: posttitle: 《Java并發(fā)編程的藝術(shù)》筆記categories: Javaexcerpt...
    xiaogmail閱讀 6,018評(píng)論 1 19

友情鏈接更多精彩內(nèi)容