本文主要介绍线程池的基本使用
上述其他介绍在上一篇文章中:实现线程的多种方式&锁的介绍&ThreadLocal&线程池 详细总结(上)-优快云博客
线程池
5.1、为什么使用线程池

线程池可以看做是管理了
N
个线程的池子,和连接池类似
5.2、认识线程池
5.2.1、线程池继承体系
在
Java 1.5
之后就提供了线程池
ThreadPoolExecutor
,它的继承体系如下:
ThreadPoolExecutor :线程池
Executor: 线程池顶层接口,提供了
execute
执行线程任务的方法
Execuors: 线程池的工具类,通常使用它来创建线程池
示例:
public static void main(String[] args) {
ExecutorService executorService = Executors.newFixedThreadPool(5);
for (int i = 0 ; i < 200 ; i++){
executorService.execute(new Runnable() {
@Override
public void run() {
//有5个线程在执行
try {
Thread.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName()+":线程执 行了...");
}
});
}
}
}
运行结果:
5.3、线程池原理
5.3.1、执行流程
我们以一个生活中的举例来理解:
1.
老陈要开软件公司,合伙几个核心的程序员做开发 :
(
线程核心数
)
2.
新的项目过来一个人接收一个项目去做,没有人手了,把新进来的项目放入项目排队池
(
任务队列
)
3.
如果项目队列中的任务过多,需要招聘一些临时的程序员
(
非核心线程
)
,但是规定所有的开发总人数不能50(
最大线程数
)
4.
如果新的项目进来,核心程序员和临时程序员都没有人手了,并且项目队列也放满了,新来的项目该如何处理呢?
1
、拒绝
2
、丢弃老的项目做新的项目
3
、老陈自己做新的项目
线程提交优先级:核心
->
队列
->
非核心
线程执行优先级:核心
->
非核心
->
队列
1
、线程池刚创建时,里面没有一个线程。任务队列是作为参数传进来的。不过,就算队列里面有任务,线程池也不会马上执行它们。
2
、当调用
execute()
方法添加一个任务时,线程池会做如下判断:
a) 如果正在运行的线程数量小于
corePoolSize
,那么马上创建线程运行这个任务;
b) 如果正在运行的线程数量大于或等于
corePoolSize
,那么将这个任务放入队列;
c) 如果这时候队列满了,而且正在运行的线程数量小于
maximumPoolSize
,那么还是要创建非核
心线程立刻运行这个任务;
d) 如果队列满了,而且正在运行的线程数量等于
maximumPoolSize
,那么线程池会抛出异常
RejectExecutionException
。
3
、当一个线程完成任务时,它会从队列中取下一个任务来执行。
4
、当一个线程无事可做,超过一定的时间(
keepAliveTime
)时,线程池会判断,如果当前运行的线程数大于
corePoolSize
,那么这个线程就被停掉。所以线程池的所有任务完成后,它最终会收缩到
corePoolSize
的大小。
5.3.2、线程池核心构造器
线程池源码
ThreadPoolExecutor
构造器:
线程池7个参数的构造器非常重要

最低0.47元/天 解锁文章
2117

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



