线程池

参考:https://www.jianshu.com/p/125ccf0046f3

一、为什么创建线程池

A、提高响应速度
B、降低创建和销毁线程的开销
C、统一管理,协同调度

二、参数

coreSize:核心线程数
maxSize:最大线程数
keepAliveTime:保活时间
TreadFactory:线程工厂,线程池类型
Handler:拒绝策略:直接抛错,不抛错忽略,忽略最老的任务等
Quence:任务队列。有界数组,无界链表,有界队列,优先级队列

三、执行原理

先打满核心线程—>再打满任务队列—>最后打满最大线程数

1.如果任务队列满了,并且最大线程数也满了,那就执行拒绝策略
2.如果任务线程执行完成,检查当前线程是否大于核心线程数,小于最大核心线程数,则进行线程销毁。如果设置了存活时间,也会看当前线程是否大于设置的存活时间,大于才销毁,要不然hold主

四、线程配置原则

1、CPU密集型:cpu个数+1

2、IO密集型:cpu个数*N. N 一般取2

3、看情况定夺,遵循公式

cpu个数*(1+w/c).

w:等待时间,可以理解为IO时间,如:DB读取,缓存读取,RPC调用
C:计算时间,可以理解为CPU活动时间,业务逻辑代码运行时间

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值