码迷,mamicode.com
首页 > 其他好文 > 详细

Executor, ExecutorService 和 Executors 间的不同

时间:2018-10-16 12:02:30      阅读:127      评论:0      收藏:0      [点我收藏+]

标签:pool   技术分享   比较   bubuko   高效   取消   固定   区别   practice   

一、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 间的不同

标签:pool   技术分享   比较   bubuko   高效   取消   固定   区别   practice   

原文地址:https://www.cnblogs.com/hahajava/p/9796923.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!