Java線程池基礎介紹

来源:https://www.cnblogs.com/hehuahua/archive/2023/07/03/17511344.html
-Advertisement-
Play Games

一、線程池的優點 1、線程池能夠復用已經創建了的線程來執行任務,從而降低了頻繁創建和銷毀線程所帶來的資源消耗; 2、任務創建完成時,不必等待線程的創建,能夠立即執行,提高了任務響應的速度。 二、創建線程池的七大核心參數 1、corePoorSize 核心線程數 線程池中長期存活的線程數量。一般情況下 ...


一、線程池的優點

  1、線程池能夠復用已經創建了的線程來執行任務,從而降低了頻繁創建和銷毀線程所帶來的資源消耗;

  2、任務創建完成時,不必等待線程的創建,能夠立即執行,提高了任務響應的速度。

 

二、創建線程池的七大核心參數

  1、corePoorSize 核心線程數

     線程池中長期存活的線程數量。一般情況下,當線程處於空閑狀態時也不會被銷毀。

  2、maximumPoorSize 最大線程數

     線程池中允許創建的最大線程數量。當線程池隊列滿後,能夠創建的最大線程數量(核心線程總數量 + 非核心線程總數量)。

  3、keepAliveTime 存活時間

     非核心線程的最大空閑時間。當非核心線程處於空閑狀態的時長到達這個時間,就會被銷毀。

  4、TimeUnit 時間單位

     存活時間的時間單位。

  5、workQueue 線程池工作隊列

     存放工作任務的阻塞隊列。當有任務被提交時,若沒有線程能夠處理,該任務就會被放到隊尾,等待線程執行。

  6、threadFactory 線程工廠

     創建一個新的線程時,用到的線程工程。可以用來設置線程名等線程參數。

  7、handler 拒絕策略

     當線程池中的工作線程數量達到了最大線程數量,並且工作隊列也容量也滿了,此時有任務提交進來時,需要做的處理。

 

三、線程池的執行流程

 如圖,線程池的執行策略可以分為三個步驟:

  1、當任務提交時,若此時的工作線程數小於核心線程數,則會創建一個線程來執行任務;

  2、當核心線程數已滿時,如果此時阻塞隊列沒有滿,則將任務放入到阻塞隊列中,等待線程執行;

  3、若核心線程數和阻塞隊列都已滿時,會去判斷當前線程數是否達到最大線程數,沒有達到就會創建一個非核心線程來執行任務,達到就執行拒絕策略。

 

四、常用的四種工作隊列

  1、ArrayBlockingQueue 基於數組的有界阻塞隊列

    當核心線程數已滿,會將新的任務放到隊列當中,並按照FIFO的順序等待線程調度。若隊列中的任務達到給定的數值,則會啟動新的線程去執行任務,若當前線程數量到達最大線程數量,則拒絕執行任務。

  2、LinkedBlockingQuene 基於鏈表的無界阻塞隊列

    也是按照FIFO的,容量為Integer類型的最大值,所以近似於無界。所以maxPoolSize此時就是無效的,因為隊列無界,能夠不斷添加任務,導致不會去創建非核心線程,線程數量最多等於核心線程數量,達不到最大線程數量。

  3、SynchronousQuene 不緩存任務的阻塞隊列

    相當於沒有隊列,噹噹前線程數達到corePoolSize時,直接創建非核心線程執行任務,噹噹前線程數到達maxPoolSize後,則拒絕任務。

  4、PriorityBlockingQueue 具有優先順序的無界阻塞隊列

    預設情況下,元素採用自然順序升序排列,也可以自定義類,然後實現compareTo()方法來指定元素排序規則。

 

五、常用的四種拒絕策略

  1、AbortPolicy

    中止策略,直接拋出 RejectedExecutionException 錯誤。線程池預設使用的策略。

    編寫一個簡單的執行deno:

public static void main(String[] args) {
        // 創建一個線程池
        ThreadPoolExecutor poolExecutor = new ThreadPoolExecutor(2, 5, 3L, TimeUnit.MINUTES, new ArrayBlockingQueue<>(1), new ThreadPoolExecutor.AbortPolicy() );

        for (int i = 0; i < 100; i++) {
            int finalI = i;
            poolExecutor.execute(() -> {
                try {
                    Thread.sleep(1000);
                    System.out.println("[" + Thread.currentThread().getName() + "]:" + finalI + "同學完成");
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            });
        }
        poolExecutor.shutdown();
    }

     執行結果:達到最大線程數後,直接拋出錯誤

 

  2、CallerRunsPolicy 

    調用者執行策略,將任務返回給提交該任務的線程執行。

    執行demo不變,將執行策略換為CallerRunsPolicy,運行結果:

     可見,因為我們的main線程提交任務給線程池後,線程池隊列及線程數量都已滿,便將執行的任務返回給main線程,由main線程執行。

  3、DiscardPolicy

    丟棄策略,將該任務丟棄,且不拋出異常。

    執行demo不變,將執行策略換為DiscardPolicy,運行結果:

     達到最大線程數後,不執行提交的任務。

  4、DiscardOldestPolicy

    丟棄最老的策略,丟棄隊列最前面的任務。

    執行demo不變,將執行策略換為DiscardOldestPolicy,運行結果:

     0~5號任務執行過程中,不斷有新的任務提交,最後執行到了第99號任務,因為前面的不斷被丟棄,99最後被放入隊列並被線程執行。


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

-Advertisement-
Play Games
更多相關文章
  • ### 前言 今天在對接阿裡雲OSS對象存儲, 把這過程記錄下來 ### 鏈接 阿裡雲的內容很多,文檔是真的難找又難懂 本文主要是用的PostObject API 加上 Callback參數 PostObject -> [https://help.aliyun.com/document_detail ...
  • 某日二師兄參加XXX科技公司的C++工程師開發崗位第31面: > 面試官:`strcpy`函數使用過吧? > > 二師兄:用過。 > > 面試官:這個函數有什麼作用? > > 二師兄:主要用做字元串複製,將於字元從一個位置複製到另一個位置。 > > 面試官:`strncpy`函數也使用過吧,和`st ...
  • 開源地址:https://gitee.com/chejiangyi/jar-protect 介紹 java 本身是開放性極強的語言,代碼也容易被反編譯,沒有語言層面的一些常規保護機制,jar包很容易被反編譯和破解。 受classfinal(已停止維護)設計啟發,針對springboot日常項目開發, ...
  • # 一. 安裝Go語言開發環境 ## 1. Wondows下搭建Go開發環境 ### (1). 下載SDK工具包 **sdk下載地址為:**[__https://go.dev/dl/__](https://go.dev/dl/) ![](https://tcs-devops.aliyuncs.com ...
  • 前幾天在項目讀取resources目錄下的文件時碰到一個小坑,明明在本地是可以正常運行的,但是一發到測試環境就報錯了,說找不到文件,報錯信息是:class path resource [xxxx] cannot be resolved to absolute file path because it... ...
  • 哈嘍大家好,我是鹹魚 今天我們從幾個方面來比較一些現在流行的兩個 python web 框架——Flask 和 Django,突出它們的主要特性、優缺點和簡單案例 到最後,大家將更好地瞭解哪個框架更適合自己的特定需求 參考鏈接:https://djangocentral.com/flask-vs-d ...
  • GO 語言中 chan 的理解 ### chan 的底層實現是怎麼樣的? > chan 是 Go 語言中的一個關鍵字,用於實現併發通信。chan 可以用於在不同的 goroutine 之間傳遞數據,實現數據的同步和非同步傳輸。 在底層實現上,chan 是通過一個結構體來表示的,這個結構體包含了一個指向 ...
  • 序列化的目的是將對象變成位元組序列,這樣一來方便持久化存儲到磁碟,避免程式運行結束後對象就從記憶體里消失,另外位元組序列也更便於網路運輸和傳播 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...