欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

源碼分析Java中ThreadPoolExecutor的底層原理

 更新時間:2023年05月07日 09:06:24   作者:向豬羊  
這篇文章主要帶大家從源碼分析一下Java中ThreadPoolExecutor的底層原理,文中的示例代碼講解詳細,具有一定的學習價值,需要的可以參考一下

一、根據(jù)代碼查看jdk提供的3種線程池創(chuàng)建

public class TestController {
    public static void main(String[] args) {
        ExecutorService executorService = Executors.newCachedThreadPool();//快
        ExecutorService executorService1 = Executors.newFixedThreadPool(10);//慢
        ExecutorService executorService2 = Executors.newSingleThreadExecutor();//很慢

        for (int i = 0; i < 100; i++) {
            executorService.execute(new MyTask(i));
        }
    }
}

class MyTask implements Runnable{
    private int i;

    public MyTask(int i) {
        this.i = i;
    }

    @Override
    public void run() {
        System.out.println(Thread.currentThread()+"-"+i);
        try {
            Thread.sleep(1000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
}

在運行過程中可以發(fā)現(xiàn)3者速度有所差別,當然3者的速度要根據(jù)實際處理自行判別,此處只以此代碼業(yè)務為例。

二、3種方式源碼分析

1、Executors.newCachedThreadPool()

源碼參數(shù)為:

0, 
Integer.MAX_VALUE,
60L, 
TimeUnit.SECONDS,
new SynchronousQueue<Runnable>()

以下圖中的外包公司為例(結合圖觀看),corePoolSize為0,即核心員工數(shù)為0;maximumPoolSize為Integer.MAX_VALUE,即非核心員工數(shù)為2的31次方-1;且BlockingQueue為同步隊列。當任務進來后分配給隊列,通過隊列分配給非核心員工,下一個任務再進入隊列,以此循環(huán)執(zhí)行,直到任務執(zhí)行完成或者非核心員工都沒有空閑時,執(zhí)行拒絕策略。

2、Executors.newFixedThreadPool(10)

源碼參數(shù)為:

nThreads, 
nThreads,
0L, 
TimeUnit.MILLISECONDS,
new LinkedBlockingQueue<Runnable>()

以下圖中的外包公司為例(結合圖觀看),corePoolSize為10,即核心員工數(shù)為10;maximumPoolSize為10,即無非核心員工,且BlockingQueue為鏈表隊列,鏈表隊列最大數(shù)為2的31次方-1,若到達最大值后執(zhí)行拒絕策略。當任務進來后分配10個任務給10個核心員工,其余任務進入鏈表隊列,當核心員工有空閑時將鏈表隊列中的某任務給與空閑員工。以此循環(huán)執(zhí)行。

3、Executors.newSingleThreadExecutor()

源碼參數(shù)為:

1, 
1,
0L, 
TimeUnit.MILLISECONDS,
new LinkedBlockingQueue<Runnable>()

以下圖中的外包公司為例(結合圖觀看),corePoolSize為1,即核心員工數(shù)為1;maximumPoolSize為1,即無非核心員工,且BlockingQueue為鏈表隊列,鏈表隊列最大數(shù)為2的31次方-1,若到達最大值后執(zhí)行拒絕策略。當任務進來后分配1個任務給1個核心員工,其余任務進入鏈表隊列,當核心員工有空閑時將鏈表隊列中的某任務給與空閑員工。以此循環(huán)執(zhí)行。

三、自定義方式執(zhí)行

    public class TestController {
    public static void main(String[] args) {
        ExecutorService executorService = Executors.newCachedThreadPool();//快
        ExecutorService executorService1 = Executors.newFixedThreadPool(10);//慢
        ExecutorService executorService2 = Executors.newSingleThreadExecutor();//很慢
        ThreadPoolExecutor threadPoolExecutor = new ThreadPoolExecutor(10, 20,
                                0L, TimeUnit.MILLISECONDS,
                                            new ArrayBlockingQueue<Runnable>(10));
        for (int i = 0; i < 100; i++) {
            threadPoolExecutor.execute(new MyTask(i));
        }
    }
}

運行結果如圖:

當線程執(zhí)行到任務30時將會報出異常,為什么下面還會繼續(xù)執(zhí)行任務11-20呢?

其實這與提交優(yōu)先級、執(zhí)行優(yōu)先級有關

提交優(yōu)先級

在執(zhí)行任務1-10是會將任務直接給核心員工,當任務11-20進來后會分配到隊列等待,此時任務21-30進來后發(fā)現(xiàn)隊列與核心員工中都存在任務,會將其分配給非核心員工執(zhí)行。當40以后的任務進來后,由于沒有空閑人員,將會拋出異常。

執(zhí)行優(yōu)先級

在執(zhí)行任務1-10是會將任務直接給核心員工,任務11-20進來后會分配給非核心員工執(zhí)行,當任務21-30進來后會分配到隊列等待。當40以后的任務進來后,由于沒有空閑人員,將會拋出異常。

以上就是源碼分析Java中ThreadPoolExecutor的底層原理的詳細內(nèi)容,更多關于Java ThreadPoolExecutor的資料請關注腳本之家其它相關文章!

相關文章

  • java代碼效率優(yōu)化方法(推薦)

    java代碼效率優(yōu)化方法(推薦)

    下面小編就為大家?guī)硪黄猨ava代碼效率優(yōu)化方法(推薦)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-01-01
  • Jmeter?BeanShell?內(nèi)置變量vars、props、prev的使用詳解

    Jmeter?BeanShell?內(nèi)置變量vars、props、prev的使用詳解

    這篇文章主要介紹了Jmeter?BeanShell?內(nèi)置變量vars、props、prev的使用?,文中給大家介紹了Jmeter中關于BeanShell的相關知識,結合實例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2022-10-10
  • 實例解析如何正確使用Java數(shù)組

    實例解析如何正確使用Java數(shù)組

    同一種類型數(shù)據(jù)的集合。其實數(shù)組就是一個容器。運算的時候有很多數(shù)據(jù)參與運算,那么首先需要做的是什么下面我們就一起來看看。
    2016-07-07
  • java如何讀取某個文件夾中的全部文件(包括子文件夾)

    java如何讀取某個文件夾中的全部文件(包括子文件夾)

    這篇文章主要介紹了java如何讀取某個文件夾中的全部文件(包括子文件夾),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • springmvc學習筆記-返回json的日期格式問題的解決方法

    springmvc學習筆記-返回json的日期格式問題的解決方法

    本篇文章主要介紹了springmvc學習筆記-返回json的日期格式問題的解決方法,解決了日期格式的輸出,有興趣的可以了解一下。
    2017-01-01
  • SpringBoot+Redis海量重復提交問題解決

    SpringBoot+Redis海量重復提交問題解決

    在實際的開發(fā)項目中,一個對外暴露的接口往往會面臨很多次請求,所以本文介紹一下SpringBoot+Redis海量重復提交問題解決,感興趣的可以了解一下
    2023-12-12
  • JAVA使用ElasticSearch查詢in和not in的實現(xiàn)方式

    JAVA使用ElasticSearch查詢in和not in的實現(xiàn)方式

    今天小編就為大家分享一篇關于JAVA使用Elasticsearch查詢in和not in的實現(xiàn)方式,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2018-12-12
  • SpringBoot如何使用mica-xss防止Xss攻擊

    SpringBoot如何使用mica-xss防止Xss攻擊

    這篇文章主要介紹了SpringBoot如何使用mica-xss防止Xss攻擊問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • 基于Process#waitFor()阻塞問題的解決

    基于Process#waitFor()阻塞問題的解決

    這篇文章主要介紹了Process#waitFor()阻塞問題的解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • Java日常練習題,每天進步一點點(44)

    Java日常練習題,每天進步一點點(44)

    下面小編就為大家?guī)硪黄狫ava基礎的幾道練習題(分享)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧,希望可以幫到你
    2021-07-07

最新評論