• 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中的任务
    没有提供和关闭线程池有关的方法 提供了关闭线程池的方法

     

  • 相关阅读:
    GoCN每日新闻(2019-11-03)
    GoCN每日新闻(2019-11-02)
    GoCN每日新闻(2019-11-01)
    GoCN每日新闻(2019-10-31)
    GoCN每日新闻(2019-10-30)
    GoCN每日新闻(2019-10-29)
    xms西软预定列表-房类市场
    GoCN每日新闻(2019-10-28)
    GoCN每日新闻(2019-10-27)
    GoCN每日新闻(2019-10-26)
  • 原文地址:https://www.cnblogs.com/hahajava/p/9796923.html
Copyright © 2020-2023  润新知