1. 线程池是什么?
- 在创建线程和销毁线程的时候,需要使用一定的资源开销;
- 使用多线程的场景很多,需要频繁使用线程的时候,如果每个线程执行结束便销毁,就会不断重复创建线程->使用线程->销毁线程的操作,浪费大量的资源在创建和销毁线程的工作上;
- 为了避免这种资源浪费,更合理的利用系统资源,那么就需要使用到池化技术了;
- 创建一定数量的共享线程放入一个池子中,当有任务执行时便将从池子里抽取出线程使用,使用完了之后再将线程放回线程池,用于循环利用。
2. 常用的线程池有哪些?
- 我们常见的线程池通常可以通过
Executors
得到,但是不建议直接使用Executors
对象创建线程池; - 线程池的种类主要根据其核心线程数量,非核心线程数量,非核心线程的存活时间三项参数的不同来区分的;
- 常见的线程池种类:
- 单线程线程池:仅有一个核心线程,没有非核心线程的线程池
- 固定线程线程池:固定数量的核心线程,没有非核心线程的线程池,常使用的线程池;
- 自动回收线程池:没有核心线程,不限数量的非核心线程,非核心线程存活一定时间。使用场景是应对任务不均匀的场景,在任务非高峰期节省线程资源,在任务高峰期的时候常见多个线程来满足任务需求,快速完成任务,并在结束任务之后销毁线程。
- 定时调度线程池:线程数量不限制,支持定时调度执行线程。
3. 不同线程池的使用场景是什么?
- 单线程线程池:主要是为了让任务按提交的顺序执行。
- 固定线程线程池:负载比较重,而且负载比较稳定的一个场景。
- 自动回收线程池:负载不稳定的场景,低峰期销毁空闲线程,回收资源,高峰期创建线程,需要多少创建多少,快速完成任务。
4. 说一下线程池配置的几个参数以及线程池启动线程的原理(说说线程池的底层原理)?
-
线程池全部总共有个参数,具体如下:
-
核心线程数量
-
最大线程数量
-
空闲线程等待时间
-
空闲线程等待时间单位
-
线程工厂
-
拒绝策略
-
线程池的原理如下:
5. 线程池被关闭的方式有哪几种?
- 主要的关闭方式有两种
shutdown/优雅关闭
和shutdownNow/立即关闭
- shutdown:不允许提交新的任务,等待前面所有的任务执行完了,才会真正的关闭线程池;
- shutdownNow:返回还没有执行的task列表,立即强制关闭线程池。
6. 线程池队列满的时候怎么处理(FixedThreadPool满了之后会怎么办)?
- 当线程池的等待队列满了,线程数量也满了之后,再提交任务到线程池的话,将会触发线程池的拒绝策略
RejectedExecutionHandler
; - JDK默认定一个几种拒绝策略,同时也支持开发者自定义策略:
- AbortPolicy:在当前线程抛出拒绝接收任务的错误;
- CallerRunsPolicy:如果线程池没有关闭,在当前线程执行该任务;
- DiscardOldestPolicy:将任务等待队列顶部任务弹出抛弃,将新添加的任务添加进程等待队列;
- DiscardPolicy:抛弃当前任务;
- 使用
Executors
创建的线程池默认使用AbortPolicy
策略
网友评论