大 ⁄ 評論關閉 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