91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java線程池怎么用

發布時間:2021-05-31 10:03:03 來源:億速云 閱讀:132 作者:小新 欄目:開發技術

小編給大家分享一下Java線程池怎么用,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

一、什么是線程池?

線程池是一種用于實現計算機程序并發執行的軟件設計模式。線程池維護多個線程,等待由調度程序分配任務以并發執行,該模型提高了性能,并避免了由于為短期任務頻繁創建和銷毀線程而導致的執行延遲。

二、線程池要解決什么問題?

說到線程池就一定要從線程的生命周期講起。

Java線程池怎么用

從圖中可以了解無論任務執行多久,每個線程都要經歷從生到死的狀態。而使用線程池就是為了避免線程的重復創建,從而節省了線程的NewRunnableRunningTerminated的時間;同時也會復用線程,最小化的節省系統資源,于此同時提高了響應速度。

三、線程池的使用

線程池的創建

使用ThreadPoolExecutor并配置7個參數完成線程池的創建

public ThreadPoolExecutor(int corePoolSize,
                              int maximumPoolSize,
                              long keepAliveTime,
                              TimeUnit unit,
                              BlockingQueue<Runnable> workQueue,
                              ThreadFactory threadFactory,
                              RejectedExecutionHandler handler)
  • corePoolSize:線程池中核心線程的最大值

  • maximumPoolSize:線程池中最大線程數

  • keepAliveTime:非核心線程空閑的存活時間大小

  • unit:keepAliveTime的單位,常用的有秒、分鐘、小時等

  • workQueue:阻塞隊列類型

  • threadFactory:線程工廠,用于配置線程的名稱,是否為守護線程等

  • handler:線程池的拒絕策略

四、常用阻塞隊列

ArrayBlockingQueue

底層基于數組的實現的有界阻塞隊列

LinkedBlockingQueue

底層基于單鏈表的阻塞隊列,可配置容量,不配置容量默認為Integer.MAX_VALUE

五、線程工廠

在《阿里巴巴Java開發手冊》中強制要求指定線程的名稱

Java線程池怎么用

由于工作是使用hutool比較多,里面也包含對ThreadFactory的封裝,可以很方便的指定名稱

ThreadFactory threadFactory = ThreadFactoryBuilder.create().setNamePrefix("myThread-").build();

六、拒絕策略

當線程池內工作線程數大于maximumPoolSize時,線程就不再接受任務,執行對應的拒絕策略;目前支持的拒絕策略有四種:

1.AbortPolicy(默認):丟棄任務并拋出RejectedExecutionException異常

2.CallerRunsPolicy:由調用者處理

3.DiscardOldestPolicy:丟棄隊列中最前面的任務,并重新入隊列

4.DiscardPolicy:丟棄任務但不拋出異常

七、線程池的執行邏輯

// 創建線程工廠
ThreadFactory threadFactory = ThreadFactoryBuilder.create().setNamePrefix("myThread-").build();
// 創建線程池
ThreadPoolExecutor threadPoolExecutor = new ThreadPoolExecutor(5, 10, 10, TimeUnit.SECONDS, new ArrayBlockingQueue<>(100), threadFactory, new ThreadPoolExecutor.AbortPolicy());

八、execute()方法

// 組合值;保存了線程池的工作狀態和工作線程數
private final AtomicInteger ctl = new AtomicInteger(ctlOf(RUNNING, 0));
public void execute(Runnable command) {
    	// 任務為空 拋出NPE
        if (command == null)
            throw new NullPointerException();
        // 獲取線程池狀態
        int c = ctl.get();
        // 如果工作線程數小于核心線程數就創建新線程
        if (workerCountOf(c) < corePoolSize) {
            if (addWorker(command, true))
                return;
            c = ctl.get();
        }
        // 如果線程池處于Running狀態,就把任務放在隊列尾部
        if (isRunning(c) && workQueue.offer(command)) {
            // 重新檢查線程池狀態
            int recheck = ctl.get();
            // 如果線程池不是Running狀態,就移除剛才添加的任務,并執行拒絕策略
            if (! isRunning(recheck) && remove(command))
                reject(command);
            // 是Running狀態,就添加線程
            else if (workerCountOf(recheck) == 0)
                addWorker(null, false);
        }
        // 添加任務失敗,執行拒絕策略
        else if (!addWorker(command, false))
            reject(command);
    }
// addWorker()完成線程的創建

九、執行流程

Java線程池怎么用

以上是“Java線程池怎么用”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

仁怀市| 怀集县| 赞皇县| 阳朔县| 西吉县| 镇康县| 沅江市| 尚义县| 富源县| 丽水市| 芒康县| 姜堰市| 中江县| 涿鹿县| 阿鲁科尔沁旗| 环江| 法库县| 泰宁县| 建宁县| 周口市| 洱源县| 都兰县| 佛坪县| 河间市| 元谋县| 额敏县| 定西市| 象州县| 衡山县| 多伦县| 昌吉市| 营山县| 庆安县| 西乌| 江门市| 南京市| 论坛| 贺州市| 民和| 永登县| 博罗县|