Executor是java.util.concurrent包中的任務執行器,他的作用是管理Thread對象,從而簡化併發編程。他的類型爲接口,子接口爲:ExecutorService
ScheduledExecutorService。所有的實現類有:AbstractExecutorService, ForkJoinPool, ScheduledThreadPoolExecutor, ThreadPoolExecutor。作
爲任務和客戶端之間的一個間接層,客戶端無須直接顯示的啓動任務和管理任務的生命週期,就夠幫助客戶端管理任務的執行。(在這裏順便吐槽
一下Executor和Executors,名字這麼相像,弄的很容易混淆,Executor是一個接口,Executors是一個繼承與Object的類,Executors中的方法全都是
一些產生線程池的靜態方法,Executors中的大部分靜態方法產生的線程池對象類型都是Executor的子類類型或者子接口類型。
Executor只是一個接口,其中定義了一個方法:execute()。Executor不需要怎麼學習,主要是要了解Executors類中那些產生Executor對象類型的線程
池方法。下面我們就使用一個小例子來了解Executor的使用。
public class MyExecutor {
public static void main(String[] args) {
ExecutorService exec = Executors.newFixedThreadPool(5);
for (int i = 0; i < 5; i++) {
exec.execute(new play(i));
}
exec.shutdown();
}
}
class play implements Runnable{
int num;
public play(int num){
this.num = num;
}
@Override
public void run() {
System.out.println("The num is "+num);
}
}
執行結果:
The num is 0
The num is 3
The num is 1
The num is 2
The num is 4
The num is 1
The num is 0
The num is 3
The num is 4
The num is 2
........
每次執行的結果都不相同,可見execute方法是異步執行的,也就是說不是等到上一個任務執行完畢之後,下一個任務提交的。每個任務的執行都互
不干涉。如果想同步執行的話,則需要添加相應的鎖機制。