线程池(三):线程池排队机制

本文详细介绍了Java线程池的核心参数,包括corePoolSize、maximumPoolSize、keepAliveTime和workQueue,以及线程池的运行原理。强调了任务队列在不同场景下的选择,如直接提交、无界队列、有界队列和优先级队列,并讨论了线程池的拒绝策略。此外,还提到了线程池参数调整对资源管理和性能的影响。
摘要由CSDN通过智能技术生成

ThreadFactory threadFactory,

RejectedExecutionHandler handler);

1)corePoolSize 核心线程数

(2)maximumPoolSize 最大线程数

(3)keepAliveTime 线程被回收前的空闲时间

(4)workQueue 任务队列

(5)threadFactory 线程创建工厂

(6)handler 线程池对拒绝任务的处理策略

(b)ThreadPoolExecutor运行原理:

ThreadPoolExecutor将根据corePoolSize和maximumPoolSize设置的值调整线程池大小。当新任务调用方法execute(Runnable)提交时,如果运行的线程少于corePoolSize,则创建新线程来处理请求。如果正在运行的线程数等于corePoolSize时,则新任务被添加到队列中,直到队列满。当队列满了后,会继续开辟新线程来处理任务,但不超过最大线程数。当任务队列满了并且已开辟了最大线程数,此时又来了新任务,ThreadPoolExecutor会拒绝服务。

(c)keepAliveTime注意事项:

/**

  • Timeout in nanoseconds for idle threads waiting for work.

  • Threads use this timeout when there are more than corePoolSize

  • present or if allowCoreThreadTimeOut. Otherwise the

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值