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接口。

 

上一篇:pyhon 启动一个下载服务器
下一篇:报错没有挂载点:mountpoint for devices not found 解决方案 docker

发表评论

最新留言

路过,博主的博客真漂亮。。
[***.116.15.85]2025年04月14日 15时21分10秒