您好,登錄后才能下訂單哦!
java中自定義線程池的原理是什么,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
1.如何管理線程
2.如何定義工作線程以及工作線程如何持續的保持運行狀態
3.如何定義線程池大小及隊列大小
4.如何提供接口給調用者使用
5.如何關閉線程池中的線程
接下來我們就一一的實現這幾個問題。
1.我們需要定義一個隊列來來管理線程,這里使用了LinkedBlockingQueue
// 1.定義一個存儲線程隊列 private LinkedBlockingQueue<Runnable> queue;
2.因為是一個簡單的測試,所以我們可以先定義一個內部類來實現工作線程
// 2.定義工作線程進行線程的執行 class Worker extends Thread { private SelfThreadPoolExecutor threadPoolExecutor; public Worker(SelfThreadPoolExecutor poolExecutor) { this.threadPoolExecutor = poolExecutor; } @Override public void run() { Runnable task; while (threadPoolExecutor.receiveTask || threadPoolExecutor.queue.size() > 0) { try { // 有線程則取出來,否則等待 System.out.println("準備消費線程"); task = threadPoolExecutor.queue.take(); if (task != null) { task.run(); System.out.println("消費線程"); } } catch (InterruptedException e) { e.printStackTrace(); } } } }
SelfThreadPoolExecutor是外部定義的整體類名
3.使用有參的構造方法進行線程池大小的管理
// 3.存放工作線程的集合 private List<Worker> workerList; // 4.線程池初始化 public SelfThreadPoolExecutor(int coreSize, int queueSize) { if (coreSize <= 0 || queueSize <= 0) { throw new IllegalArgumentException("參數不正確"); } this.queue = new LinkedBlockingQueue<>(queueSize); // 線程安全的集合 this.workerList = Collections.synchronizedList(new ArrayList<>()); for (int i = 0; i < coreSize; i++) { Worker worker = new Worker(this); worker.start(); workerList.add(worker); } }
4.定義阻塞和非阻塞的方式提供對應的接口
// 5.非阻塞的方法接口 public boolean offer(Runnable task) { if (receiveTask) { return queue.offer(task); } else { return false; } } // 6.阻塞的方法接口 public void put(Runnable task) { try { if (receiveTask) { queue.put(task); } } catch (InterruptedException e) { e.printStackTrace(); } }
6.進行線程池的關閉
// 7.線程池的關閉 private boolean receiveTask = true; public void shutdown() { // 7.1.隊列不再接收線程 receiveTask = false; // 7.2.關閉處于wait或block的線程 for (Thread thread : workerList) { if (Thread.State.BLOCKED.equals(thread.getState()) || Thread.State.WAITING.equals(thread.getState()) || Thread.State.TIMED_WAITING.equals(thread.getState())){ thread.interrupt(); } } }
我們測試的方法如下:
public static void main(String [] args){ SelfThreadPoolExecutor selfThreadPoolExecutor = new SelfThreadPoolExecutor(5,10); for(int i = 0;i < 20;i++){ Runnable task = () ->{ System.out.println("開啟線程"); }; selfThreadPoolExecutor.put(task); } selfThreadPoolExecutor.shutdown(); }
運行結果是:
準備消費線程 準備消費線程 準備消費線程 準備消費線程 準備消費線程 開啟線程 消費線程 準備消費線程 開啟線程 消費線程 準備消費線程 開啟線程 消費線程 準備消費線程 。。。。。。
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。