Executor的原理是什么


这篇文章给大家介绍Executor的原理是什么,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。Executor: java线程池框架的最上层父接口,在Executor中只有executor()方法,该方法表示提交Runnable类型线程池并执行。ExecutorService: Executor的子接口,该接口中submit()方法可接收Runnable参数或Callable参数,在使用结束后使用shutdown()方法关闭线程池,不再接收新的任务。AbstractExecutorService: ExecutorService的默认实现类。ScheduledExecutorService: ExecutorService的子接口,可供定时任务调度的接口。ScheduledThreadPoolExecutor: 提供了另一种线程池,延迟执行和周期性执行的线程池。ThreadPoolExecutor: Java线程池最核心的一个类,该类继承自AbstractExecutorService主要功能是创建线程池,给任务分配线程资源,执行任务。ThreadPoolExecutor有多个重载的构造方法,我们基于最完整的构造方法来分析每个参数的作用。corePoolSize与maximumPoolSize相等,即其线程全为核心线程,是一个固定大小的线程池,是其优势;keepAliveTime = 0 该参数默认对核心线程无效,而FixedThreadPool全部为核心线程;workQueue 为LinkedBl 香港云主机ockingQueue(无界阻塞队列),队列最大值为Integer.MAX_VALUE。如果任务提交速度持续大余任务处理速度,会造成队列大量阻塞。因为队列很大,很有可能在拒绝策略前,内存溢出。是其劣势;FixedThreadPool的任务执行是无序的;控制线程池中corePoolSize与maximumPoolSize都为1FinalizableDelegatedExecutorService继承DelegatedExecutorService,DelegatedExecutorService最终继承AbstractExecutorService,该类是线程池的一个代理模式的实现,相比于ThreadPoolExecutor阉割一部分功能,形成线程池单例化。corePoolSize = 0,maximumPoolSize = Integer.MAX_VALUE,即线程数量几乎无限制keepAliveTime = 60s,60s后空闲线程自动结束SynchronousQueue 为同步队列,入队出队必须同时传递,因为CachedThreadPool线程创建无限制,不会有队列等待newScheduledThreadPool为定长线程池,限定核心线程数ScheduledThreadPoolExecutor方法中对线程池参数做了进一步的封装,设置maximumPoolSize = Integer.MAX_VALUE,keepAliveTime = 0调用scheduleAtFixedRate()方法可进行周期性任务设置ForkJoinPool继承AbstractExecutorService,ForkJoinPool可以充分利用多核cpu的优势,将一个任务拆分成多个“小任务”并行计算,提高任务的执行时间关于Executor的原理是什么就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

相关推荐: C++怎么实现strStr()函数

本文小编为大家详细介绍“C++怎么实现strStr()函数”,内容详细,步骤清晰,细节处理妥当,希望这篇“C++怎么实现strStr()函数”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。ImplementstrStr().Retur…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 07/26 11:24
下一篇 07/26 11:24

相关推荐