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方法是异步执行的,也就是说不是等到上一个任务执行完毕之后,下一个任务提交的。每个任务的执行都互

不干涉。如果想同步执行的话,则需要添加相应的锁机制。

你可能感兴趣的:(Java 线程与并发研究系列一Executor简介与使用)