成人视屏在线观看-国产99精品-国产精品1区2区-欧美一级在线观看-国产一区二区日韩-色九九九

您的位置:首頁技術文章
文章詳情頁

Java如何固定大小的線程池

瀏覽:47日期:2022-08-10 11:15:07
1.固定大小的線程池簡介

線程池就是在程序啟動的時候先建立幾個可以使用的線程放在那里,然后等著具體的任務放進去,這個任務基本可以說都是Runnable的實現類,因此它減小了系統每次新建和銷毀線程的開銷,但同時增加了維護這些線程的開銷,個中取舍看具體情況而定。

固定大小的線程池就是在啟動的時候創建了固定個數的線程放在那里等待使用。

2.包裝一個線程池對象

public class TaskPool{ private final ThreadPoolExecutor executor = (ThreadPoolExecutor)Executors.newFixedThreadPool(9); // 創建一個大小為9的固定線程池,可以按照CPU的核數初步判定,如果CPU密集性任務則創建N+1個,如果是IO密集型任務則創建2N+1個,其中N即CPU的核數 protected void shutdown(){// do something// 這個方法等待線程池中所有已提交任務執行結束,不接收新任務,然后結束executor.shutdown(); // 這個強制結束所有任務,然后正在等在的任務列表// executor.shutdownNow(); } protected void execute(Runnable command){// do something// 提交任務executor.execute(command); } public void status(){StringBuffer sb = new StringBuffer();// 當前正在執行任務的線程數sb.append(executor.getActiveCount() + 'n'); // 當前正在等待執行的線程數sb.append(executor.getQueue().size() + 'n'); // 返回已經完成的線程數sb.append(executor.getCompletedTaskCount() + 'n'); System.out.println(sb.toString());// 注:以上方法都是返回一個大概值,因為線程在執行中,這些狀態隨時都會改變 }} 3.使用線程池

public class Launcher{ private TaskPool taskPool = new TaskPool(); public static void main(String[] args){// 新建100個任務,Runnable的實現類TaskTask[] tasks = new Task[100];for (int i = 0; i < tasks.length; i++){ tasks[i] = new Task('Task ' + (i+1)); // 提交到線程池運行 taskPool.execute(task[i]); if ( i % 50 == 0){taskPool.status();} } private static class Task implements Runnable{private String name;public Task(String name){ this.name = name;}public void run(){ // do something System.out.println('我的名字是:' + this.name);} }}Java線程池小拓展線程池的介紹

1 常用的 池化技術

C3P0

DBCP

2 線程池的衍生

頻繁的創建線程對象和多線程之間進行上下文切換,是非常耗時間和資源的所以JDK1.5中提出了線程池技術

3 使用線程池

Exector

4 線程池的創建

創建一個固定大小的線程池 ( 最常用的方法 )

ExecutorService pool = Executors.newFixedThreadPool(2);Runnable task = new Runnable() {@Overridepublic void run() {while (true) {try {Thread.sleep(1000);} catch (InterruptedException e) {e.printStackTrace();}System.out.println(Thread.currentThread().getName());}}};pool.execute(task);pool.execute(task);pool.execute(task);//線程池的帶下只有兩個 現在這個任務在其等待隊列中排隊等候

創建可變大小的線程池

ExecutorService pool = Executors.newCachedThreadPool();Runnable task = new Runnable() {@Overridepublic void run() {while (true) {try {Thread.sleep(1000);} catch (InterruptedException e) {e.printStackTrace();}System.out.println(Thread.currentThread().getName());}}};pool.execute(task);pool.execute(task);pool.execute(task);

創建獨立任務的線程池

ExecutorService pool = Executors.newSingleThreadExecutor();Runnable task = new Runnable() {@Overridepublic void run() {while (true) {try {Thread.sleep(1000);} catch (InterruptedException e) {e.printStackTrace();}System.out.println(Thread.currentThread().getName());}}};pool.execute(task);pool.execute(task);pool.execute(task);

創建可調度的線程池

ScheduledExecutorService threadPool = Executors.newScheduledThreadPool(2);Runnable task = new Runnable() {@Overridepublic void run() {while (true) {try {Thread.sleep(1000);} catch (InterruptedException e) {e.printStackTrace();}System.out.println(Thread.currentThread().getName());}}};threadPool.schedule(task, 2000, TimeUnit.MILLISECONDS);

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Java
相關文章:
主站蜘蛛池模板: 亚洲免费片| 亚洲精品一区二区在线播放 | 色久综合网 | 日韩专区亚洲精品欧美专区 | 精品久久久中文字幕二区 | 5级做人爱c视版免费视频 | 精品国产_亚洲人成在线高清 | 91成人免费观看在线观看 | 久久影院在线 | 亚洲精品一区二区三区网址 | 欧美视频一区在线观看 | 在线播放精品一区二区啪视频 | 国产1区2区三区不卡 | 成人国产精品久久久免费 | 久久91视频 | 亚洲精品一区二区综合 | 一色屋色费精品视频在线观看 | 国产成在线观看免费视频成本人 | 国产剧情一区二区 | a级片免费 | 美女视频免费永久观看的 | 精品在线免费观看 | 特黄特黄一级高清免费大片 | 成人网中文字幕色 | 欧美人成在线视频 | 欧美一级成人毛片影院 | 99视频在线免费看 | 国产欧美日韩精品a在线观看 | a级国产乱理伦片在线观看 a级国产乱理伦片在线观看99 | 中日韩精品视频在线观看 | 精品成人在线观看 | 好看的看黄a大片爽爽影院 好男人天堂网 | 国产极品喷水视频jk制服 | 国产成人精品综合久久久 | 亚洲日本免费 | 亚洲一区在线观看视频 | 日韩久久网 | 久草综合在线观看 | 风流慈禧一级毛片在线播放 | 欧美日韩顶级毛片www免费看 | 免费在线一区二区三区 |