线程池

线程池

1.线程池的目的:

减少创建和销毁线程的开销,提高线程资源利用率;提高响应的速度。

2.线程池的七大参数:

核心进程数、最大进程数、多余线程存活时间、时间单位、阻塞队列类型、处理线程的工厂ThreadFactory、拒绝策略

其中拒绝策略的情况,表示队列和线程池都满了的情况,对任务采取的一种策略:
1.直接抛出异常
2.不处理,丢弃掉
3.用调用者所在的线程来处理当前任务
4.丢弃队列里面最近的一个任务,并执行当前任务

3.Java可以通过Executors类来创建四种线程:

(1)newCachedThreadPool创建一个可缓存线程池。核心线程数为0;无界;空余线程最多存活60秒,阻塞队列是SynchronousQueue。
SynchronousQueue简单来说线程执行的offer()插入操作与空闲线程执行的poll()弹出操作配对成功。如果SynchronousQueue中没有线程,则创建一个新任务成为空闲线程,然后把主线程提交给这个新任务。
适用场景:任务量大但耗时少的任务。

(2)newFixedThreadPool创建一个定长的线程池。核心进程数等于最大进程数根据具体设置的参数;超过核心进程数时,多余线程将会立即停止;阻塞队列是LinkedBlockingQueue。
LinkedBlockingQueue是无界的,由于是无界的,当线程池的线程数达到corePoolSize后,新任务将在无界队列中等待。有空闲线程就去队列里面取任务。
适用场景:任务量比较固定但是耗时长的任务。

(3)newSingleThreadExecutor创建一个单线程化的线程池,核心进程数和最大线程数都是1,阻塞队列是LinkedBlockingQueue
适用场景:多个任务顺序执行的场景

(4)newScheduledThreadPool创建一个周期性的线程池。核心进程数根据具体参数设置。非核心进程数没有限制。阻塞队列是:DelayedWorkQueue。DelayedWorkQueue会将任务排序。
使用场景:执行周期性的任务

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值