栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

ThreadPoolExecutor 饱和策略?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

ThreadPoolExecutor 饱和策略?

如果当前同时运行的线程数量达到最大线程数量并且队列也已经被放满了任时,

ThreadPoolTaskExecutor
定义一些策略:

  • ThreadPoolExecutor.AbortPolicy
    :抛出
    RejectedExecutionException
    来拒绝新任务的处理。
  • ThreadPoolExecutor.CallerRunsPolicy
    :调用执行自己的线程运行任务,也就是直接在调用
    execute
    方法的线程中运行(
    run
    )被拒绝的任务,如果执行程序已关闭,则会丢弃该任务。因此这种策略会降低对于新任务提交速度,影响程序的整体性能。另外,这个策略喜欢增加队列容量。如果您的应用程序可以承受此延迟并且你不能任务丢弃任何一个任务请求的话,你可以选择这个策略。
  • ThreadPoolExecutor.DiscardPolicy
    不处理新任务,直接丢弃掉。
  • ThreadPoolExecutor.DiscardOldestPolicy
    此策略将丢弃最早的未处理的任务请求。

举个例子:

Spring 通过

ThreadPoolTaskExecutor
或者我们直接通过
ThreadPoolExecutor
的构造函数创建线程池的时候,当我们不指定
RejectedExecutionHandler
饱和策略的话来配置线程池的时候默认使用的是
ThreadPoolExecutor.AbortPolicy
。在默认情况下,
ThreadPoolExecutor
将抛出
RejectedExecutionException
来拒绝新来的任务 ,这代表你将丢失对这个任务的处理。 对于可伸缩的应用程序,建议使用
ThreadPoolExecutor.CallerRunsPolicy
。当最大池被填满时,此策略为我们提供可伸缩队列。(这个直接查看
ThreadPoolExecutor
的构造函数源码就可以看出,比较简单的原因,这里就不贴代码了。)

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/363355.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号