一、什么是线程池
类似于数据库连接池,为了能够复用线程、限制并发数以及减少上下文切换带来的资源消耗,使用池化的技术对线程进行管理。
二、线程池如何使用
jdk给我们提供了Executor框架,来创建和使用线程池,架构图如下:
主要使用的是Executor接口、ExecutorService接口、ThreadPoolExecuor类和Executors工具类。
1、Executor接口
此接口是一个函数式接口,只有一个待实现的方法,用来执行一项Runnable任务
2、ExecutorService接口
此接口是Executor的子接口,对其进行了扩展,功能更加强大,我们一般使用它来代替Executor。
可以看到,除了原来的execute方法外,它还提供了submit方法来提交Callable任务,以及一些改变线程池状态的方法。
3、ThreadPoolExecutor类
线程池的常用实现类,普通方法不再展示,重要的是四个静态内部类和它的构造方法。
ThreadPoolExecutor的构造器最多可以接收7个参数,它们分别是: