大战熟女丰满人妻av-荡女精品导航-岛国aaaa级午夜福利片-岛国av动作片在线观看-岛国av无码免费无禁网站-岛国大片激情做爰视频

Java多線程編程概述
Java多線程的安全問題
Java多線程同步
Java多線程間的通信
Java線程Lock
Java多線程管理
保障線程安全的設計技術
Java鎖的優化及注意事項
Java多線程集合
【Java多線程】單例模式與多線程

Java線程池的底層實現

查看Executors工具類中newCachedThreadPool(), newSingleThreadExcecutor(), newFixedThreadPool()源碼:

   public static ExecutorService newCachedThreadPool() {
        return new ThreadPoolExecutor(0, Integer.MAX_VALUE,
                                      60L, TimeUnit.SECONDS,
                                      new SynchronousQueue());
}
該線程池在極端情況下,每次提交新的任務都會創建新的線程執行. 適合用來執行大量耗時短并且提交頻繁的任務
    public static ExecutorService newFixedThreadPool(int nThreads) {
        return new ThreadPoolExecutor(nThreads, nThreads,
                                      0L, TimeUnit.MILLISECONDS,
                                      new LinkedBlockingQueue());
    }
    public static ExecutorService newSingleThreadExecutor() {
        return new FinalizableDelegatedExecutorService
            (new ThreadPoolExecutor(1, 1,
                                    0L, TimeUnit.MILLISECONDS,
                                    new LinkedBlockingQueue()));
    }
Excutors工具類中返回線程池的方法底層都使用了ThreadPoolExecutor線程池,這些方法都是ThreadPoolExecutor線程池的封裝。
ThreadPoolExecutor的構造方法:
    public ThreadPoolExecutor(int corePoolSize,
                                   int maximumPoolSize,
                                   long keepAliveTime,
                                   TimeUnit unit,
                                   BlockingQueue workQueue,
                                   ThreadFactory threadFactory,
                                   RejectedExecutionHandler handler)
各個參數含義:

corePoolSize, 指定線程池中核心線程的數量。

maxinumPoolSize,指定線程池中最大線程數量。

keepAliveTime,當線程池線程的數量超過corePoolSize時,多余的空閑線程的存活時長,即空閑線程在多長時長內銷毀。

unit, 是keepAliveTime時長單位。

workQueue,任務隊列,把任務提交到該任務隊列中等待執行。

threadFactory,線程工廠,用于創建線程。

handler拒絕策略,當任務太多來不及處理時,如何拒絕。

說明:

workQueue工作隊列是指提交未執行的任務隊列,它是BlockingQueue接口的對象,僅用于存儲Runnable任務.根據隊列功能分類,在ThreadPoolExecutor構造方法中可以使用以下幾種阻塞隊列:

1、直接提交隊列,由SynchronousQueue 對象提供,該隊列沒有容量,提交給線程池的任務不會被真實的保存,總是將新的任務提交給線程執行,如果沒有空閑線程,則嘗試創建新的線程,如果線程數量已經達到maxinumPoolSize規定的最大值則執行拒絕策略。

2、有界任務隊列,由ArrayBlockingQueue實現,在創建ArrayBlockingQueue對象時,可以指定一個容量. 當有任務需要執行時,如果線程池中線程數小于corePoolSize核心線程數則創建新的線程;如果大于corePoolSize核心線程數則加入等待隊列.如果隊列已滿則無法加入,在線程數小于maxinumPoolSize指定的最大線程數前提下會創建新的線程來執行,如果線程數大于maxinumPoolSize最大線程數則執行拒絕策略。

3、無界任務隊列,由LinkedBlockingQueue對象實現,與有界隊列相比,除非系統資源耗盡,否則無界隊列不存在任務入隊失敗的情況. 當有新的任務時,在系統線程數小于corePoolSize核心線程數則創建新的線程來執行任務;當線程池中線程數量大于corePoolSize核心線程數則把任務加入阻塞隊列。

4、優先任務隊列是通過 PriorityBlockingQueue實現的,是帶有任務優先級的隊列,是一個特殊的無界隊列.不管是ArrayBlockingQueue隊列還是LinkedBlockingQueue隊列都是按照先進先出算法處理任務的.在PriorityBlockingQueue隊列中可以根據任務優先級順序先后執行。

全部教程
主站蜘蛛池模板: 国产精品99爱免费视频 | 欧美日韩国产精品综合 | 日本xoxoxo在线播放 | 99热成人| 欧美美妇性较大毛片 | 久精品视频 | 久久久久免费精品国产 | 男人女人真曰批的视频动态 | 在线国产欧美 | 欧美巨大xxxx做受孕妇视频 | 国产在线99 | 色综合久久综精品 | 999国产高清在线精品 | 国产一区在线观看视频 | 亚洲欧美一区二区三区久久 | 色综合亚洲天天综合网站 | 福利院肉动漫视频在线观看 | 成人a一级毛片免费看 | 久久99精品一区二区三区 | 校园春色男人天堂 | 国内精品免费一区二区观看 | 中国精品久久精品三级 | 精品久久伦理中文字幕 | 欧美成人毛片免费网站 | 日本在线无 | 亚洲毛片在线看 | 国产精品亚洲欧美一区麻豆 | 欧美在线一级精品 | 久久毛片久久毛 | 米奇7777| 中文字幕日韩高清 | 奇米影视7777777| 97av视频在线播放 | 日本99热 | 欧美精品香蕉在线观看网 | 国产精品夜色7777青苹果 | 久久精品亚洲综合 | 久久美女网 | 五月婷婷在线免费观看 | 91精品欧美产品免费观看 | 久草婷婷在线 |