一、为什么要有线程池?
Java中的线程池是运用场景最多的并发框架,几乎所有需要异步或并发执行任务的程序
都可以使用线程池。在开发过程中,合理地使用线程池能够带来3个好处。
1.降低资源的消耗。通过重复利用已创建的线程降低线程的创建和销毁造成的消耗。
2.提高响应效率。当任务到达时,任务可以不需要等待线程创建就能执行。
3.提高线程的可管理性。线程是稀缺资源,如果无限制地创建,不仅会消耗系统资源,
还会降低系统的稳定性,使用线程池可以进行统一分配、调优和监控。
二、线程池的类的继承关系?

三、ThreadPoolExecutor的研究?
1、属性
private final AtomicInteger ctl = new AtomicInteger(ctlOf(RUNNING, 0));
private static final int COUNT_BITS = Integer.SIZE - 3;
private static final int CAPACITY = (1 << COUNT_BITS) - 1;//容量的大小2^29-1;
线程池中的线程有五种状态
private static final int RUNNING = -1 << COUNT_BITS;//接收新任务并且处理队列中的任务
private static final int SHUTDOWN = 0 << COUNT_BITS;//不接收新的任务,但是处理队列中的任务
private static final int STOP = 1 << COUNT_BITS;//不接收新的任务,不处理队列中的任务,中断正在处理任务
private static final int TIDYING = 2 << COUNT_BITS;//所有的任务都停止了,工作线程的数目为0,线程在转换到该状态时会调用中断方法
private static final int TERMINATED = 3 << COUNT_BITS;//调用了中断方法
2、构造函数

四、Executors静态工厂几种常用线程池

线程池
最新推荐文章于 2025-03-29 15:46:57 发布
170万+

被折叠的 条评论
为什么被折叠?



