package com.dy.pool; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; /** * 在Executors類裏面提供了一些靜態工廠,生成一些經常使用的線程池。 * 1. newSingleThreadExecutor * 建立一個單線程的線程池。這個線程池只有一個線程在工做,也就是至關於單線程串行執行全部任務。 * 若是這個惟一的線程由於異常結束,那麼會有一個新的線程來替代它。 * 此線程池保證全部任務的執行順序按照任務的提交順序執行 */ public class SingleThreadExecutor { public static void main(String[] args) { System.out.println("歡迎來到線程世界!"); //建立一個可重用固定線程數的線程池 ExecutorService pool = Executors.newSingleThreadExecutor(); //建立實現了Runnable接口對象,Thread對象固然也實現了Runnable接口 SingleThreadExecutor.MyThread t1 = new SingleThreadExecutor().new MyThread("實例t1"); SingleThreadExecutor.MyThread t2 = new SingleThreadExecutor().new MyThread("實例t2"); SingleThreadExecutor.MyThread t3 = new SingleThreadExecutor().new MyThread("實例t3"); SingleThreadExecutor.MyThread t4 = new SingleThreadExecutor().new MyThread("實例t4"); //將線程放入池中進行執行 pool.execute(t1); pool.execute(t2); pool.execute(t3); pool.execute(t4); //關閉線程池 pool.shutdown(); } class MyThread extends Thread { public MyThread(String name){ super(name); } @Override public void run() { System.out.println(this.getName() + "正在執行。。。"); System.out.println(Thread.currentThread().getName() + "正在執行。。。"); } } }
另外說下 代碼中的this.getName和Thread.currentThread().getName(): java
前者的this是指實例對象自身,後者是指實例對象中的當前執行線程;兩者不要理解混淆了! ide