ThreadPoolExecutor線程池任務執行失敗的時候會怎樣

来源:https://www.cnblogs.com/cjsblog/archive/2018/12/05/10073838.html
-Advertisement-
Play Games

接上一篇 《JDK1.8中的線程池》 1. 任務執行失敗時的處理邏輯 1.1. Worker Worker相當於線程池中的線程 可以看到,Worker有幾個重要的屬性: thread : 這是Worker運行的線程,可以理解為一個Worker就是一個線程 firstTask : 初始任務,可能為為n ...


接上一篇 《JDK1.8中的線程池

1.  任務執行失敗時的處理邏輯

1.1.  Worker

Worker相當於線程池中的線程

可以看到,Worker有幾個重要的屬性:

  • thread : 這是Worker運行的線程,可以理解為一個Worker就是一個線程
  • firstTask : 初始任務,可能為為null
  • completedTasks : Worker完成的任務數

同時,還應該註意到,在構造方法中給thread賦值為一個新線程。由於Worker實現了Runnable介面,也就是說它本身就是可執行的任務,當它啟動的時候理所當然應該運行run()方法,而它的run()方法中調用了runWorker(this)方法

1.2.  Worker是如何創建的

主要是:創建Workder對象,並將該對象加入到Worker集合中,最後啟動Worker(PS:啟動Worker中的線程是啟動Worker)

1.3.  runWorker(this)

可以看到,創建線程的時候傳的是this,this代表的是Worker對象,而Worker是一個Runnable,因此當調用線程的start()方法後執行的是Worker的run()方法,而Worker的run()方法裡面調用的時候runWorker(this),因此,接下來重點看一下runWorker(this)

如果task.run()方法拋異常,則會被catch捕捉到,但是catch又將異常拋出去了,外層的兩個try沒有捕獲,跳出迴圈,執行3個finally

我們只看最後一個finally

看到這裡,一切真相大白

當任務執行失敗後,該Workder會被從Worker集合中刪除,然後,只要線程池當前還在繼續處理任務,則重新創建一個新的Worker

也就是說,任務執行失敗後,原來的Worker就死了,如果線程池還在繼續處理任務,則再創建一個新的Worker

2.  拒絕策略

  

四種策略:

  1. 直接拋異常(預設)
  2. 什麼也不做,也不拋異常
  3. 如果線程池當期處於RUNNING狀態,則執行這個任務,否則什麼也不做
  4. 如果線程池當前處於RUNNING狀態,則刪除隊列頭部的任務,然後將該任務加到工作任務隊列中

3.  其它相關

JDK1.8中的線程池

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 代理模式是一種很常用的模式,JDK也內置了對於代理的支持,動態代理,本文對代理模式進行了介紹,意圖,結構,java實現,對靜態代理和動態代理進行了分析,並且給出了代碼示例,並且介紹了CGLIB的使用。 ...
  • 外觀模式又稱為門面模式Facade是一種簡單的設計模式,但是他背後的思想為迪米特原則,理解門面模式更有助於理解迪米特原則--不要和陌生人說話的原則,可以降低系統的耦合程度,本文介紹了外觀模式的意圖,結構,並且給出了java代碼示例。 ...
  • List 是 Java 開發中經常會使用的集合,你們知道有哪些方式可以初始化一個 List 嗎?這其中不缺乏一些坑,今天棧長我給大家一一普及一下。 1、常規方式 這種就是我們平常用的最多最平常的方式了,沒什麼好說的,後面缺失的泛型類型在 JDK 7 之後就可以不用寫具體的類型了,改進後會自動推斷類型 ...
  • 前言 開心一刻 已經報廢了一年多的電腦,今天特麽突然開機了,嚇老子一跳,只見電腦管家緩緩地出來了,本次開機一共用時一年零六個月,打敗了全國0%的電腦,電腦管家已經對您的電腦失去信心,然後它把自己卸載了,只剩我在一旁發呆。 路漫漫其修遠兮,吾將上下而求索! github:https://github. ...
  • 題目內容: NMEA-0183協議是為了在不同的GPS(全球定位系統)導航設備中建立統一的BTCM(海事無線電技術委員會)標準,由美國國家海洋電子協會(NMEA-The National Marine Electronics Associa-tion)制定的一套通訊協議。GPS接收機根據NMEA-0 ...
  • php
    1、location.href='http://www.xxx.com/'; 2、location.replace('http://www.xxx.com/'); phpstudy運用在後端 ------伺服器:提供服務的機器------ 通過功能變數名稱訪問 給電腦配伺服器 靜態頁面就是數據不變 數據變化... ...
  • 第一步 由於mysql版本問題 先嘗試打開 sudo vim /etc/mysql/my.cnf 如空,再嘗試打開 sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf # 號 註釋該行 bind-address = 127.0.0.1 第二步 進入mysql my ...
  • 對於一個純小白來說,安裝一個MySQL不是那麼容易,本來是按照老師給的步驟,一步一步進行應該不會出現什麼錯誤的,但由於個人電腦內部的配置問題,在安裝過程中不斷出問題,我覺得更重要的原因應該在於我,我作為一個純小白,你跟我說啥文件查找路徑錯誤,我都不知道去哪找這個配置路徑,反正關於操作系統的知識,我是 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...