一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Java 線程池框架

Java 線程池框架

2020-08-04 15:44月光下的鳳尾竹 Java教程

本文主要介紹了Java 線程池框架的相關知識。具有很好的參考價值,下面跟著小編一起來看下吧

一、線程池結構圖

Java 線程池框架

二、示例

定義線程接口

?
1
2
3
4
5
6
public class MyThread extends Thread {
 @Override
 publicvoid run() {
 System.out.println(Thread.currentThread().getName() + "正在執行");
 }
}

1:newSingleThreadExecutor

?
1
2
3
4
5
6
7
8
9
10
ExecutorService pool = Executors. newSingleThreadExecutor();
 Thread t1 = new MyThread();
 Thread t2 = new MyThread();
 Thread t3 = new MyThread();
 //將線程放入池中進行執行
 pool.execute(t1);
 pool.execute(t2);
 pool.execute(t3);
 //關閉線程池
 pool.shutdown();

輸入結果:

?
1
2
3
pool-1-thread-1正在執行
pool-1-thread-1正在執行
pool-1-thread-1正在執行

2:newFixedThreadPool

?
1
2
3
4
5
6
7
8
9
10
11
12
13
ExecutorService pool = Executors.newFixedThreadPool(3);
Thread t1 = new MyThread();
 Thread t2 = new MyThread();
 Thread t3 = new MyThread();
 Thread t4 = new MyThread();
 Thread t5 = new MyThread();
 //將線程放入池中進行執行
 pool.execute(t1);
 pool.execute(t2);
 pool.execute(t3);
 pool.execute(t4);
 pool.execute(t5);
pool.shutdown();

輸入結果:

?
1
2
3
4
pool-1-thread-1正在執行
pool-1-thread-2正在執行
pool-1-thread-1正在執行
pool-1-thread-2正在執行

3 :newCachedThreadPool

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
ExecutorService pool = Executors.newCachedThreadPool();
 Thread t1 = new MyThread();
 Thread t2 = new MyThread();
 Thread t3 = new MyThread();
 Thread t4 = new MyThread();
 Thread t5 = new MyThread();
 //將線程放入池中進行執行
 pool.execute(t1);
 pool.execute(t2);
 pool.execute(t3);
 pool.execute(t4);
 pool.execute(t5);
 //關閉線程池
 pool.shutdown();

輸入結果:

?
1
2
3
4
5
pool-1-thread-2正在執行
pool-1-thread-4正在執行
pool-1-thread-3正在執行
pool-1-thread-1正在執行
pool-1-thread-5正在執行

4 :ScheduledThreadPoolExecutor

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
ScheduledExecutorService pool = Executors.newScheduledThreadPool(2);
pool.scheduleAtFixedRate(new Runnable() {//每隔一段時間就觸發異常
  @Override
  public void run() {
   //throw new RuntimeException();
   System.out.println("================");
  }
 }, 1000, 2000, TimeUnit.MILLISECONDS);
pool.scheduleAtFixedRate(new Runnable() {//每隔一段時間打印系統時間,證明兩者是互不影響的
  @Override
  public void run() {
   System.out.println("+++++++++++++++++");
  }
 }, 1000, 2000, TimeUnit.MILLISECONDS);

輸入結果:

?
1
2
3
4
================
+++++++++++++++++
+++++++++++++++++
+++++++++++++++++

三、線程池核心參數

corePoolSize : 池中核心的線程數

maximumPoolSize : 池中允許的最大線程數。

keepAliveTime : 當線程數大于核心時,此為終止前多余的空閑線程等待新任務的最長時間。

unit : keepAliveTime 參數的時間單位。

workQueue : 執行前用于保持任務的隊列。此隊列僅保持由 execute方法提交的 Runnable任務。

threadFactory : 執行程序創建新線程時使用的工廠。

handler : 由于超出線程范圍和隊列容量而使執行被阻塞時所使用的處理程序。

ThreadPoolExecutor :Executors類的底層實現。

3.1 任務排隊機制

SynchonousQueue: 同步隊列,隊列直接提交給線程執行而不保持它們,此時線程池通常是無界的

LinkedBlockingQueue: 無界對列,當線程池線程數達到最大數量時,新任務就會在隊列中等待執行,可能會造成隊列無限膨脹

ArrayBlockingQueue : 有界隊列,有助于防止資源耗盡,一旦達到上限,可能會造成新任務丟失

注意:

newSingleThreadExecutor、newFixedThreadPool使用的是LinkedBlockingQueue

newCachedThreadPool 使用的是 SynchonousQueue

newScheduledThreadPool使用的是 DelayedWorkQueue

3.2 線程執行流程

Java 線程池框架

3.3 線程大小確定:

cpu密集型: 盡量少開線程,最佳線程數 Ncpu+1

io密集型:多開線程,2Ncpu

混合型:根據情況而定,可以拆分成io密集和cou密集

以上就是本文的全部內容,希望本文的內容對大家的學習或者工作能帶來一定的幫助,同時也希望多多支持服務器之家!

原文鏈接:http://www.cnblogs.com/wanwusheng/p/6376311.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 疯狂伦交1一6小说 | 亚洲国产AV一区二区三区四区 | 秋霞一级黄色片 | 久久亚洲一级α片 | 思思99热久久精品在2019线 | 国产欧美日韩在线播放 | 国产精品怡红院永久免费 | 日本强不卡在线观看 | 国产在线乱子伦一区二区 | 边打电话边操 | 虎四免费入口 | 91九色国产porny | 学校女性奴sm训练调教 | 午夜在线观看免费完整直播网 | 我的好妈妈7中字在线观看韩国 | 狠狠撸在线播放 | 国产精品嫩草影院在线看 | 无限好资源免费观看 | 99在线观看国产 | 美女视频一区二区三区在线 | 婷婷去我也去 | 国产尤物视频 | 青青草国产精品 | 91一区二区在线观看精品 | 狠狠综合网 | 国产日韩欧美在线一区二区三区 | 国产成人久久精品一区二区三区 | 按摩椅play啊太快了h | 欧美成人momandson | 婷婷综合七月激情啪啪 | 91热这里只有精品 | 国产午夜一区二区在线观看 | 免费日本视频 | 欧美video丝袜连裤袜bd | 3d动漫被吸乳羞羞 | 欧美一区二区三区视视频 | 国产一区二区精品久久91 | 国产一级视频久久 | 日本免费高清在线 | 欧亚尺码专线欧洲s码wmy | 奇米777狠狠 |