亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Java > 正文

以實例簡介Java中線程池的工作特點

2019-11-26 14:59:56
字體:
來源:轉載
供稿:網友

什么原因使我們不得不使用線程池?

個人認為主要原因是:短時間內需要處理的任務數量很多

使用線程池的好處:

1.減少在創建和銷毀線程上所花的時間以及系統資源的開銷
2.如不使用線程池,有可能造成系統創建大量線程而導致消耗完系統內存

以下是Java自帶的幾種線程池:

1、newFixedThreadPool  創建一個指定工作線程數量的線程池。

每當提交一個任務就創建一個工作線程,如果工作線程數量達到線程池初始的最大數,則將提交的任務存入到池隊列中。

2、newCachedThreadPool 創建一個可緩存的線程池。

這種類型的線程池特點是:

1).工作線程的創建數量幾乎沒有限制(其實也有限制的,數目為Interger. MAX_VALUE), 這樣可靈活的往線程池中添加線程。

2).如果長時間沒有往線程池中提交任務,即如果工作線程空閑了指定的時間(默認為1分鐘),則該工作線程將自動終止。終止后,如果你又提交了新的任務,則線程池重新創建一個工作線程。

3、newSingleThreadExecutor 創建一個單線程化的Executor,即只創建唯一的工作者線程來執行任務,如果這個線程異常結束,會有另一個取代它,保證順序執行(我覺得這點是它的特色)。

單工作線程最大的特點是可保證順序地執行各個任務,并且在任意給定的時間不會有多個線程是活動的 。

4、newScheduleThreadPool  創建一個定長的線程池,而且支持定時的以及周期性的任務執行,類似于Timer。

總結:

一.FixedThreadPool是一個典型且優秀的線程池,它具有線程池提高程序效率和節省創建線程時所耗的開銷的優點。但在線程池空閑時,即線程池中沒有可運行任務時,它不會釋放工作線程,還會占用一定的系統資源。

二.CachedThreadPool的特點就是在線程池空閑時,即線程池中沒有可運行任務時,它會釋放工作線程,從而釋放工作線程所占用的資源。但是,但當出現新任務時,又要創建一新的工作線程,又要一定的系統開銷。并且,在使用CachedThreadPool時,一定要注意控制任務的數量,否則,由于大量線程同時運行,很有會造成系統癱瘓。

Java線程池 ThreadPoolExecutor使用實例

package com.sondon.mayi.jpool;  import java.util.concurrent.ArrayBlockingQueue; import java.util.concurrent.Callable; import java.util.concurrent.ExecutionException; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.ThreadPoolExecutor; import java.util.concurrent.TimeUnit;  public class JPoolLearn {   private static int produceTaskSleepTime = 3;  private static int produceTaskMaxNumber = 20;    public void testThreadPoolExecutor(){   /*    * ThreadPoolExecutor(    * int corePoolSize, //線程池維護線程的最少數量    * int maximumPoolSize, //線程池維護線程的最大數量    * long keepAliveTime, //線程池維護線程所允許的空閑時間    * TimeUnit unit, //線程池維護線程所允許的空閑時間的單位    * BlockingQueue<Runnable> workQueue, //線程池所使用的緩沖隊列    * RejectedExecutionHandler handler //線程池對拒絕任務的處理策略 )    */   ThreadPoolExecutor threadPool = new ThreadPoolExecutor(     5,     10,     3,     TimeUnit.SECONDS,     new ArrayBlockingQueue<Runnable>(10),     new ThreadPoolExecutor.DiscardOldestPolicy()     );    for (int i = 1; i <= produceTaskMaxNumber; i++) {    try {     // 產生一個任務,并將其加入到線程池     String task = "task---" + i;     threadPool.execute(new ThreadPoolTask(task));     System.out.println("activeCount :"+ threadPool.getActiveCount());     // 便于觀察,等待一段時間     Thread.sleep(produceTaskSleepTime);    } catch (Exception e) {     e.printStackTrace();    }   }      //查看當前的線程池狀況   while(true){    try {     Thread.sleep(3000);     System.out.println("pool size :"+threadPool.getPoolSize());//線程池中線程數量     System.out.println("active count :"+threadPool.getActiveCount());//線程池中活動的線程數量    } catch (InterruptedException e) {     e.printStackTrace();    }   }  }   /**   *   * @Author 蔡文鋒   * @Data_Time 2015年7月25日 下午4:06:28   * @Description { 測試不同線程池模式 }   */  public void testNewCachedThreadPool(){   ThreadPoolExecutor threadPool=(ThreadPoolExecutor) Executors.newCachedThreadPool(); //  ThreadPoolExecutor threadPool=(ThreadPoolExecutor) Executors.newFixedThreadPool(100); //  ThreadPoolExecutor threadPool=(ThreadPoolExecutor) Executors.newScheduledThreadPool(100); //  ThreadPoolExecutor threadPool=(ThreadPoolExecutor) Executors.newSingleThreadExecutor();   try {   for (int i = 0; i < 100; i++) {    // 產生一個任務,并將其加入到線程池    String task = "task---" + i;    threadPool.execute(new ThreadPoolTask(task));    System.out.println("activeCount :");    // 便于觀察,等待一段時間    Thread.sleep(produceTaskSleepTime);        }   } catch (InterruptedException e) {    e.printStackTrace();   }   //查看當前的線程池狀況   while(true){    try {     Thread.sleep(3000);     System.out.println("pool size :"+threadPool.getPoolSize());//線程池中線程數量     System.out.println("active count :"+threadPool.getActiveCount());//線程池中活動的線程數量    } catch (InterruptedException e) {     e.printStackTrace();    }   }  }    /**   *   * @Author 蔡文鋒   * @Data_Time 2015年7月25日 下午4:06:58   * @Description { 測試callable與runable方法的區別 }   */  public void testNewCachedThreadPool_callable(){   ExecutorService es=Executors.newFixedThreadPool(10);   try {     //   String result=es.submit(new MyCallable<String>()).get(); //   System.out.println("callable result :"+result);        String result=(String) es.submit(new ThreadPoolTask("")).get();    System.out.println("runable result :"+result);       } catch (InterruptedException | ExecutionException e) {    e.printStackTrace();   }  }      public static void main(String[] args) {   new JPoolLearn().testNewCachedThreadPool();  } }    /**  * 線程池執行的任務  */ class ThreadPoolTask implements Runnable {  private static int consumeTaskSleepTime = 2000;  // 保存任務所需要的數據  private Object threadPoolTaskData;   ThreadPoolTask(Object tasks) {   this.threadPoolTaskData = tasks;  }   public void run() {   System.out.println("start .." + threadPoolTaskData);   try {    // Sleep 2秒 模擬耗時操作    Thread.sleep(consumeTaskSleepTime);   } catch (Exception e) {    e.printStackTrace();   }   threadPoolTaskData = null;  }   public Object getTask() {   return this.threadPoolTaskData;  } }  /**  *  * @Project : JPool  * @Package : com.sondon.mayi.jpool  * @Class : MyCallable  * @param <T>  */ class MyCallable<T> implements Callable<T>{    @Override  public T call() throws Exception {    System.out.println("開始執行Callable");    return (T) "測試callable接口";   } } 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
九九视频直播综合网| 欧美老女人性生活| 成人免费视频97| 国产精品久久久久久久av大片| 亚洲欧美另类国产| 92国产精品久久久久首页| 91精品视频在线免费观看| 欧美激情欧美狂野欧美精品| 亚洲91av视频| 欧美专区在线观看| 亚洲国产精品va在线| 亚洲视频欧洲视频| 欧美成人免费全部观看天天性色| 欧美日韩中文字幕在线视频| 97国产一区二区精品久久呦| 久久久精品久久| 国产一区二区三区直播精品电影| 国产精品久久久久高潮| 最新国产精品亚洲| 欧美猛交ⅹxxx乱大交视频| 国产午夜精品全部视频在线播放| 午夜精品久久久久久久白皮肤| 日本一区二三区好的精华液| 欧美另类极品videosbestfree| 欧美另类在线观看| 91精品国产色综合久久不卡98| 欧美性生交xxxxx久久久| 亚洲欧洲日产国产网站| 国产区亚洲区欧美区| 在线播放国产精品| 中文字幕日韩在线观看| 2019日本中文字幕| 中文字幕久热精品视频在线| 欧美成人中文字幕在线| 欧美激情免费在线| 精品国产91乱高清在线观看| 欧美激情综合色综合啪啪五月| 日韩欧美一区二区三区| 日本一区二区三区四区视频| 欧美丰满少妇xxxxx做受| 青青久久av北条麻妃海外网| 亚洲精品福利免费在线观看| 国产精品国语对白| 国产视频亚洲视频| 亚洲免费av电影| 亚洲精品有码在线| 中文字幕欧美精品日韩中文字幕| 欧美专区在线播放| 欧美日韩国产成人在线观看| 欧美亚洲在线观看| 91系列在线观看| 中文字幕日韩专区| 91久热免费在线视频| 久久成人一区二区| 91精品国产沙发| 欧美在线一级va免费观看| 九色精品美女在线| 国产亚洲精品一区二555| 91精品国产综合久久香蕉的用户体验| 九色精品美女在线| 亚洲第一免费网站| 伊人男人综合视频网| 亚洲最新在线视频| 91av中文字幕| 久久亚洲精品国产亚洲老地址| 欧美xxxx14xxxxx性爽| 久久精品中文字幕电影| 日韩福利视频在线观看| 成人春色激情网| 国产+成+人+亚洲欧洲| 欧美日韩免费观看中文| 欧美成人精品在线| 国产亚洲欧洲高清一区| 欧美在线不卡区| 精品久久国产精品| 亚洲人a成www在线影院| 色综合久久久久久中文网| 国产日韩精品在线| 日本精品免费观看| 成人免费视频xnxx.com| 久久国产精品久久久久久| 国产亚洲精品久久久| 精品国模在线视频| 国产免费成人av| 奇米4444一区二区三区| 亚洲欧洲第一视频| 欧美在线性视频| 国产91在线高潮白浆在线观看| 夜夜嗨av色一区二区不卡| 国产精品爽爽ⅴa在线观看| 成人午夜高潮视频| 中文字幕亚洲一区二区三区五十路| 亚洲欧美中文日韩在线v日本| 国产一区二区三区在线免费观看| 亚洲第一区第一页| 成人欧美在线观看| 亚洲三级免费看| 91久久久久久国产精品| 国产精自产拍久久久久久| 色综合91久久精品中文字幕| 97超碰国产精品女人人人爽| 日韩av电影中文字幕| 国产日韩精品一区二区| 奇米一区二区三区四区久久| 成人精品福利视频| 久久99国产精品久久久久久久久| 欧美裸体男粗大视频在线观看| 国产精品日韩欧美大师| 色综合久久久久久中文网| 91在线观看免费网站| 欧美大荫蒂xxx| 日韩美女视频免费在线观看| 日韩在线视频观看正片免费网站| 欧美三级xxx| 欧美日韩在线观看视频| 91精品在线播放| 国模gogo一区二区大胆私拍| 国产91ⅴ在线精品免费观看| 欧美日本在线视频中文字字幕| 成人午夜激情免费视频| 欧美激情va永久在线播放| 91色精品视频在线| 日韩精品有码在线观看| 日韩在线观看免费高清| 久久国产精品久久精品| 国产精品美女午夜av| 欧美成人在线免费视频| www欧美xxxx| 国产在线精品播放| www.亚洲天堂| 欧美成人精品一区二区| 欧美一级黑人aaaaaaa做受| 国a精品视频大全| 97久久精品视频| 88xx成人精品| 欧美性猛交xxxxx免费看| 日韩日本欧美亚洲| 91大神在线播放精品| 久久久国产视频| 这里只有精品丝袜| 欧美黑人极品猛少妇色xxxxx| 国产精品久久久久久久久久尿| 91免费电影网站| 亚洲free性xxxx护士白浆| 国产欧美日韩最新| 日日骚久久av| 色综合久久久久久中文网| 久久久久999| 亚洲精品视频网上网址在线观看| 国产97在线亚洲| 在线亚洲国产精品网| 91国偷自产一区二区三区的观看方式| 久久久999精品免费| 美女少妇精品视频| 国产精品视频精品视频| 国产精品免费一区豆花| 亚洲一级免费视频| 青青草成人在线| 欧美日韩亚洲视频一区| 色99之美女主播在线视频| 中文字幕自拍vr一区二区三区| 久久影视免费观看| 欧美野外wwwxxx| 国产美女主播一区|