Java如何固定大小的線程池
1.固定大小的線程池簡介
線程池就是在程序啟動的時候先建立幾個可以使用的線程放在那里,然后等著具體的任務放進去,這個任務基本可以說都是Runnable的實現(xiàn)類,因此它減小了系統(tǒng)每次新建和銷毀線程的開銷,但同時增加了維護這些線程的開銷,個中取舍看具體情況而定。
固定大小的線程池就是在啟動的時候創(chuàng)建了固定個數(shù)的線程放在那里等待使用。
2.包裝一個線程池對象
public class TaskPool{ private final ThreadPoolExecutor executor = (ThreadPoolExecutor)Executors.newFixedThreadPool(9); // 創(chuàng)建一個大小為9的固定線程池,可以按照CPU的核數(shù)初步判定,如果CPU密集性任務則創(chuàng)建N+1個,如果是IO密集型任務則創(chuàng)建2N+1個,其中N即CPU的核數(shù) protected void shutdown(){ // do something // 這個方法等待線程池中所有已提交任務執(zhí)行結(jié)束,不接收新任務,然后結(jié)束 executor.shutdown(); // 這個強制結(jié)束所有任務,然后正在等在的任務列表 // executor.shutdownNow(); } protected void execute(Runnable command){ // do something // 提交任務 executor.execute(command); } public void status(){ StringBuffer sb = new StringBuffer(); // 當前正在執(zhí)行任務的線程數(shù) sb.append(executor.getActiveCount() + "\n"); // 當前正在等待執(zhí)行的線程數(shù) sb.append(executor.getQueue().size() + "\n"); // 返回已經(jīng)完成的線程數(shù) sb.append(executor.getCompletedTaskCount() + "\n"); System.out.println(sb.toString()); // 注:以上方法都是返回一個大概值,因為線程在執(zhí)行中,這些狀態(tài)隨時都會改變 } }
3.使用線程池
public class Launcher{ private TaskPool taskPool = new TaskPool(); public static void main(String[] args){ // 新建100個任務,Runnable的實現(xiàn)類Task Task[] 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 線程池的衍生
頻繁的創(chuàng)建線程對象和多線程之間進行上下文切換,是非常耗時間和資源的所以JDK1.5中提出了線程池技術
3 使用線程池
Exector
4 線程池的創(chuàng)建
創(chuàng)建一個固定大小的線程池 ( 最常用的方法 )
ExecutorService pool = Executors.newFixedThreadPool(2); Runnable task = new Runnable() { @Override public 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);//線程池的帶下只有兩個 現(xiàn)在這個任務在其等待隊列中排隊等候
創(chuàng)建可變大小的線程池
ExecutorService pool = Executors.newCachedThreadPool(); Runnable task = new Runnable() { @Override public 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);
創(chuàng)建獨立任務的線程池
ExecutorService pool = Executors.newSingleThreadExecutor(); Runnable task = new Runnable() { @Override public 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);
創(chuàng)建可調(diào)度的線程池
ScheduledExecutorService threadPool = Executors.newScheduledThreadPool(2); Runnable task = new Runnable() { @Override public 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);
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
使用WebUploader實現(xiàn)上傳文件功能(一)
這篇文章主要為大家詳細介紹了使用WebUploader實現(xiàn)上傳文件功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-01-01Spring中使用JSR303請求約束判空的實現(xiàn)
這篇文章主要介紹了Spring中使用JSR303請求約束判空的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-12-12JavaFx實現(xiàn)登錄成功跳轉(zhuǎn)到程序主頁面
這篇文章主要為大家詳細介紹了JavaFx實現(xiàn)登錄成功跳轉(zhuǎn)到程序主頁面,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-06-06使用Java實現(xiàn)KMZ和KML數(shù)據(jù)的直接解析
本文主要講解如何用JAVA語言,直接解析KMZ數(shù)據(jù),文章首先介紹google地圖中的KMZ和KML數(shù)據(jù),然后使用代碼的方式實現(xiàn)數(shù)據(jù)的解析,最后展示解析成果以及如何將數(shù)據(jù)轉(zhuǎn)換成空間WKT數(shù)據(jù),需要的朋友可以參考下2024-06-06