Java 內建的線程池Executors.newFixedThreadPool__Java

來源:互聯網
上載者:User
Java 內建的線程池Executors.newFixedThreadPool 2014年08月29日  ⁄ 綜合 ⁄ 共 3920字 ⁄ 字型大小  小  中  大  ⁄ 評論關閉

  Sun在Java5中,對Java線程的類庫做了大量的擴充,其中線程池就是Java5的新特徵之一,除了線程池之外,還有很多多線程相關的內容,為多線程的編程帶來了極大便利。為了編寫高效穩定可靠的多線程程式,線程部分的新增內容顯得尤為重要。 

  有關Java5線程新特徵的內容全部在java.util.concurrent下面,裡麵包含數目眾多的介面和類,熟悉這部分API特徵是一項艱難的學習過程。目前有關這方面的資料和書籍都少之又少,大所屬介紹線程方面書籍還停留在java5之前的知識層面上。 

  當然新特徵對做多線程程式沒有必須的關係,在java5之前通用可以寫出很優秀的多線程程式。只是代價不一樣而已。 

  線程池的基本思想還是一種對象池的思想,開闢一塊記憶體空間,裡面存放了眾多(未死亡)的線程,池中線程執行調度由池管理器來處理。當有線程任務時,從池中取一個,執行完成後線程對象歸池,這樣可以避免反覆建立線程對象所帶來的效能開銷,節省了系統的資源。 

  在Java5之前,要實現一個線程池是相當有難度的,現在Java5為我們做好了一切,我們只需要按照提供的API來使用,即可享受線程池帶來的極大便利。 

  Java5的線程池分好多種:具體的可以分為兩類,固定尺寸的線程池、可變尺寸串連池。 

  在使用線程池之前,必須知道如何去建立一個線程池,在Java5中,需要瞭解的是java.util.concurrent.Executors類的API,這個類提供大量建立串連池的靜態方法,是必須掌握的。 

一、固定大小的線程池,newFixedThreadPool: [java]  view
plain copy

package app.executors;      import java.util.concurrent.Executors;   import java.util.concurrent.ExecutorService;      /**   * Java線程:線程池   *    * @author 馮小衛   */   public class Test {       public static void main(String[] args) {           // 建立一個可重用固定線程數的線程池           ExecutorService pool = Executors.newFixedThreadPool(5);           // 建立線程           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();       }   }      class MyThread extends Thread {       @Override       public void run() {           System.out.println(Thread.currentThread().getName() + "正在執行。。。");       }   }  


輸出結果: [html]  view
plain copy

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


改變ExecutorService pool = Executors.newFixedThreadPool(5)中的參數:ExecutorService pool = Executors.newFixedThreadPool(2),輸出結果是: [html]  view
plain copy

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.