4、线程池高频面试题

1、线程池的执行流程


当我们提交一个任务到线程池中,线程池的处理流程如下:

首先判断线程池里的核心线程是否都在执行任务,如果不是,则创建一个新的工作线程来执行任务。
如果核心线程都在执行任务,则判断工作队列是否已满,如果没满,则将新提交的任务存储在这个工作队列里。
如果工作队列满了,则判断线程数是否小于最大线程数,如果是,则创建临时线程直接执行任务
如果线程数已经到达了最大线程数,则会执行对应的拒绝策略逻辑
2、线程池的核心参数
线程池在创建的时候最大支持传入7个参数,分别是:

核心线程数、最大线程数、临时线程的空闲时间临时线程的空闲时间单位、工作队列长度创建线程的工厂线程池的拒绝策略

3、线程池的拒绝策略有哪些
拒绝策略是指将任务添加到线程池中时,线程池拒绝该任务所采取的相应策略,官方提供的有4种:(不用背英文,直接说中文)

AbortPolicy:直接抛出异常,默认策略

CallerRunsPolicy:用调用者所在的线程来执行任务

DiscardOldestPolicy:丢弃阻塞队列中靠最前的任务,并执行当前任务

DiscardPolicy:直接丢弃任务

 4、了解Executors创建线程池吗
了解过,Excutors是JDK提供的一个可以创建线程池的工具类,它可以创建4 种线程池

但是用它创建的线程池有的没有限制最大线程数,有的没有限制阻塞队列的长度,这样的话,极大可能导致OOM

因此我们公司不允许我们使用它,而是使用自己传递参数的方式创建线程池

5、如何确定线程池的核心线程数
线程池的核心线程数跟任务的性质有很大关系

对于CPU密集型时,任务可以少配置线程数,推荐配置为CPU核数+1,这样可以使得每个线程都在执行任务
IO密集型时,即该任务需要大量的IO,大部分线程都阻塞,则需要多配置线程数,推荐配置为CPU核数的2倍
                        
原文链接:https://blog.csdn.net/qq_17462303/article/details/134497170

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值