Executor, ExecutorService 和 Executors 间的不同

Posted hahajava

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Executor, ExecutorService 和 Executors 间的不同相关的知识,希望对你有一定的参考价值。

一、Java 线程池

Java通过Executors提供四种线程池,分别为:
1、newCachedThreadPool:  创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程。(线程最大并发数不可控制)
2、newFixedThreadPool:   创建一个定长线程池,可控制线程最大并发数,超出的线程会在队列中等待。
3、newScheduledThreadPool:创建一个定长线程池,支持定时及周期性任务执行。
4、newSingleThreadExecutor:创建一个单线程化的线程池,它只会用唯一的工作线程来执行任务,保证所有任务按照指定顺序(FIFO, LIFO, 优先级)执行。

线程池比较单线程的优势在于:

a. 重用存在的线程,减少对象创建、消亡的开销,性能佳。
b. 可有效控制最大并发线程数,提高系统资源的使用率,同时避免过多资源竞争,避免堵塞。
c. 提供定时执行、定期执行、单线程、并发数控制等功能。

参考:http://blog.csdn.net/nk_tf/article/details/51959276

Executor, ExecutorService 和 Executors 间的不同

技术分享图片

 

来自:https://www.baidu.com/link?url=8K_op4j3ORuqN8dDsh4QEesx5LUE6fKTPSoor1l1ce_0DNdRqKYyfR7y4Fti5TXvWFVIdptzr0S3CKeaIcTCKa&wd=&eqid=ebd4c02600016502000000045bc5544b
下面详细看一下三者的区别:

Executor vs ExecutorService vs Executors
正如上面所说,这三者均是 Executor 框架中的一部分。Java 开发者很有必要学习和理解他们,以便更高效的使用 Java 提供的不同类型的线程池。总结一下这三者间的区别,以便大家更好的理解:

Executor 和 ExecutorService: 区别1:     ExecutorService  接口继承了 Executor 接口


Executor 和 ExecutorService: 区别2:      Executor        接口的 execute()方法用来接收 Runnable接口     的对象,
                           而 ExecutorService  接口的 submit()  方法可以接收 Runnable接口 和 Callable接口 的对象。


Executor 和 ExecutorService: 区别3:      Executor            的 execute()   方法返回 void,
                           而 ExecutorService   的 submit()    方法可以通过一个 Future 对象返回(运算结果)。


Executor 和 ExecutorService: 区别3:除了允许客户端提交一个任务,ExecutorService 还提供用来控制线程池的方法。比如:调用 shutDown() 方法终止线程池。可通过 《Java Concurrency in Practice》了解更多关于关闭线程池和如何处理 pending 的任务的知识。
Executors 类提供工厂方法用来创建不同类型的线程池。比如: newSingleThreadExecutor()         : 创建一个只有一个线程的线程池,
                              newFixedThreadPool(int numOfThreads)    : 创建固定线程数量的线程池,
                              newCachedThreadPool():                根据需要创建新的线程,但如果已有线程是空闲的会重用已有线程。

ExecutorExecutorService
Executor 是 Java 线程池的核心接口,用来并发执行提交的任务 ExecutorService 是 Executor 接口的扩展,提供了异步执行和关闭线程池的方法
提供execute()方法用来提交任务 提供submit()方法用来提交任务
execute()方法无返回值 submit()方法返回Future对象,可用来获取任务执行结果
不能取消任务 可以通过Future.cancel()取消pending中的任务
没有提供和关闭线程池有关的方法 提供了关闭线程池的方法

 

 

以上是关于Executor, ExecutorService 和 Executors 间的不同的主要内容,如果未能解决你的问题,请参考以下文章

Executor ExecutorService Executors

java Executor, ExecutorService, Executors 有什么不同

java并发编程框架 Executor ExecutorService invokeall

ExecutorService.submit()与Executor.execute()的区别

java多线程之Executor 与 ExecutorService两个基本接口

Java并发编程 - Executor,Executors,ExecutorService, CompletionServie,Future,Callable