Java 線程與併發研究系列一Executor簡介與使用

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方法是異步執行的,也就是說不是等到上一個任務執行完畢之後,下一個任務提交的。每個任務的執行都互

不干涉。如果想同步執行的話,則需要添加相應的鎖機制。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章