1.什么是线程池
线程池是指在初始化一个多线程应用程序过程中创建一个线程集合,然后在需要执行新的任务时重用这些线程而不是新建一个线程。线程池中线程的数量通常完全取决于可用内存数量和应用程序的需求。然而,增加可用线程数量是可能的。线程池中的每个线程都有被分配一个任务,一旦任务已经完成了,线程回到池子中并等待下一次分配任务。
线程池是一种多线程处理形式,处理过程中将任务添加到队列,然后再创建线程后自动启动这些任务。线程池线程都是后台线程。每个线程都使用默认的堆栈大小,以默认的优先级运行,并处于多线程单元中。
2.为什么要用线程池
在java中频繁创建线程会大大降低系统的效率,创建和销毁线程花费的时间和耗费系统资源都比较大,同时如果在jvm中创建太多的线程,可能会使系统过度消耗内存而导致系统资源不足。
而线程池使得线程可以复用,就是执行完一个任务,并不被销毁,而是可以继续执行其他的任务,减少创建和销毁线程的次数
3. ThreadPoolExecutor
3.1.简介
ThreadPoolExecutor作为java.util.concurrent包对外提供基础实现,以内部线程池的形式对外提供管理任务执行,线程调度,线程池管理等等服务;
Executors方法提供的线程服务,都是通过ThreadPoolExecutor 构造方法
参数设置来实现不同的线程池机制。