【声明:所有思维导图均纯手工打造,转载请注明出处】
1.线程池是什么
线程池是一种通过池化思想进行线程管理的工具,提升了线程资源的客观理性,避免无限制的创建线程造成的系统内存溢出异常。实现了线程了重复利用,降低了因线程重复创建和销毁带来的资源消耗,同时依赖于已经创建好的线程能够快速对任务进行响应执行。
2.线程池解决了什么问题
1)频繁申请/销毁资源和调度资源,将带来额外的消耗,可能会非常巨大。
2)对资源无限申请缺少抑制手段,易引发系统资源耗尽的风险。
3)系统无法合理管理内部的资源分布,会降低系统的稳定性。
3.线程池工作原理概述
提交任务时判断当前运行线程数量是否到达corePoolSize,如果没有则创建一个线程(核心线程)执行任务;如果已经到达则将任务添加到任务队列中,如果这里添加失败则说明任务队列已经满了,这时新建线程并判断新添加线程是否会使当前线程数量大于线程池最大容量,如果大于的话就会触发饱和策略。
4.Executor框架
4.1核心思想
将任务的提交与任务的执行分离。
4.2 组成部分
4.Executors工厂类
用于根据需要创建不同类型的线程池,可以创建的线程池类型如下:
5.ThreadPoolExecutor
5.1主要成员变量
5.2 4种队列
5.3 4种拒绝策略
5.4 5种运行状态
5.5 提交任务的方式
5.6 核心运行机制
5.6.1 线程管理机制
5.6.2 任务管理机制
5.8 关于线程池参数的设定