一、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(): 根据需要创建新的线程,但如果已有线程是空闲的会重用已有线程。
Executor | ExecutorService |
---|---|
Executor 是 Java 线程池的核心接口,用来并发执行提交的任务 | ExecutorService 是 Executor 接口的扩展,提供了异步执行和关闭线程池的方法 |
提供execute()方法用来提交任务 | 提供submit()方法用来提交任务 |
execute()方法无返回值 | submit()方法返回Future对象,可用来获取任务执行结果 |
不能取消任务 | 可以通过Future.cancel()取消pending中的任务 |
没有提供和关闭线程池有关的方法 | 提供了关闭线程池的方法 |