91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

java中自定義線程池的原理是什么

發布時間:2021-06-11 15:51:51 來源:億速云 閱讀:117 作者:Leah 欄目:編程語言

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(); 
  }

運行結果是:

準備消費線程 
準備消費線程 
準備消費線程 
準備消費線程 
準備消費線程 
開啟線程 
消費線程 
準備消費線程 
開啟線程 
消費線程 
準備消費線程 
開啟線程 
消費線程 
準備消費線程 
。。。。。。

看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

安顺市| 渝中区| 金堂县| 玛曲县| 弥勒县| 横峰县| 奇台县| 湘阴县| 循化| 固安县| 名山县| 连江县| 玉门市| 屏南县| 松桃| 乌兰察布市| 济源市| 清涧县| 西乡县| 庄浪县| 海南省| 盐源县| 聂荣县| 叶城县| 剑川县| 文昌市| 松溪县| 黑山县| 札达县| 漳浦县| 宁安市| 商洛市| 连云港市| 霍林郭勒市| 上林县| 新野县| 柏乡县| 丹巴县| 集安市| 团风县| 资讯|