java.util.concurrent学习之 Executor

首先我们先来看一下Executor的继承树关系:

java.util.concurrent学习之 Executor_第1张图片

然后了解下各个接口或类的意思

Executor :最上层接口,里面只有execute的方法
ExecutorService : 继承Executor,提供了更多丰富的方法(submit,invokeAny,invokeAll),对ExecutorService的接口实现有两个(ThreadPoolExecutor,ScheduledThreadPoolExecutor)
				  这两个即是java线程池具体实现类。
AbstractExecutorService:ExecutorService执行方法的默认实现
ScheduledExecutorService:对其中的任务进行调度,比如延迟执行、定时执行等等
ScheduledThreadPoolExecutor:ScheduledExecutorService的实现,一个可定时调度任务的线程池
ThreadPoolExecutor:线程池,可以通过调用Executors以下静态工厂方法来创建线程池并返回一个ExecutorService对象
Executors :工厂类,创建(newCachedThreadPool,newFixedThreadPool,newScheduledThreadPool,newSingleThreadExecutor)四种类型ExecutorService线程池。
		   它的方法返回的都是ThreadPoolExecutor、ScheduledThreadPoolExecutor这两个类的实例。

应用场景,一般用来起线程异步操作一些事情,应用代码

public class Test {
	public static void main (String[] args) throws Exception {

		ExecutorService fixedThreadPool = Executors.newFixedThreadPool(20);
		fixedThreadPool.execute(new Runnable() {
			public void run() {
					System.out.println("hahaha ");
			}
		});
		
		ScheduledExecutorService scheduledThreadPool = Executors.newScheduledThreadPool(10);
		//任务调度延迟执行,使用Callable可以返回数据
		ScheduledFuture schedule = scheduledThreadPool.schedule(new Callable() {
			public String call() throws Exception{
				System.out.println("hahahahah ");
				return "xixi";
			}
		}, 5, TimeUnit.SECONDS); 
		
		String str = schedule.get();
		System.out.println(str);
		 
	}
}




你可能感兴趣的:(java.util.concurrent学习之 Executor)