
ThreadPoolExecutor 的构造方法都有哪些参数,分别代表什么意思?
发布日期:2021-05-15 04:56:54
浏览次数:20
分类:原创文章
本文共 969 字,大约阅读时间需要 3 分钟。
(1) corePoolSize线程池中常驻核心线程数。在创建了线程池后,当有请求任务来之后,就会安排池中的线程去执行请求任务。当线程池的线程数达到corePoolSize后,就会把到达的任务放到缓存队列当中。(2) maximumPoolSize线程池能够容纳同时执行的最大线程数,必须大于等于1。(3) keepAliveTime多余的空闲线程的存活时间。当前线程池数量超过corePoolSize时,当空闲时间达到keepAliveTime值时,多余空闲线程会被销毁到只剩下corePoolSize个线程为止。(4) allowCoreThreadTimeOut是否允许核心线程的空闲线程超时。默认是false。可通过allowCoreThreadTimeOut(value)方法设置。如果allowCoreThreadTimeOut设置为true,核心线程空闲时间达到keepAliveTime值时也会被销毁。(5) unitkeepAliveTime的单位。(6) workQueue任务队列,被提交但尚未被执行的任务。(7) threadFactory表示生成线程池中工作线程的线程工厂,用于创建线程一般用默认的即可。(8) handler拒绝策略,表示当队列满了并且工作线程大于等于线程池的最大线程数(maximumPoolSize)时如何来拒绝新任务执行的runable的策略。拒绝策略:(1) AbortPolicy(默认) 直接抛出RejectedExecutionException异常阻止系统正常运行.(2) CallerRunsPolicy 当触发拒绝策略,只要线程池没有关闭的话,则使用调用线程池对象的线程直接运行任务。一般并发比较小,性能要求不高,不允许失败。但是,由于调用者自己运行任务,如果任务提交速度过快,可能导致程序阻塞,性能效率上必然的损失较大。(3) DiscardOldestPolicy 抛弃队列中等待最久的任务,然后把当前任务加入队列中尝试再次提交当前任务。(4) DiscardPolicy 直接丢弃任务,不予任何处理也不抛异常。如果允许任务丢失,这是最好的一种方案。 如果需要自定义线程池拒绝任务策略,需要实现RejectedExecutionHandler接口。
发表评论
最新留言
路过,博主的博客真漂亮。。
[***.116.15.85]2025年04月14日 15时21分10秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
牛客-链表中环的入口节点(Java)
2019-03-11
堆的应用_topK算法和堆排序
2019-03-11
最大半连通子图
2019-03-11
Remove Extra one 维护前缀最大最小值
2019-03-11
另类加法,走方格的方案数,最近公共祖先
2019-03-11
[Java Path Finder][JPF学习笔记][7]JPF输出详细程度设置
2019-03-11
GitHub完整记录数据库GHTorrent的下载和安装经验
2019-03-11
设计模式—— 三:依赖倒置原则
2019-03-11
SpringBoot打包之后乱码
2019-03-11
因SGA分配错误无法启动数据库
2019-03-11
Oracle修改字段类型方法总结
2019-03-11
ORA-00020 超过当前最大连接数
2019-03-11
合理控制oracle数据库具有DBA权限的用户
2019-03-11
喝红茶是否会上火
2019-03-11
Android进阶解密读书笔记2——第2章:Android系统启动——第1、2小节
2019-03-11
GreenDao之注解
2019-03-11
Android使用Font Awesome
2019-03-11
主线程中Looper的轮询死循环为何没有阻塞主线程?
2019-03-11