1、概述
多线程并发时,频繁的创建线程和销毁线程会降低系统效率
线程池可以可以使线程执行完不销毁,继续执行别的任务
线程池是一个容器,可以使用集合
最好使用LinkedList<Thread>集合
(可以用别的)
2、实现思路
但程序第一次启动时,创建多个线程保存到集合中,当我们要使用线程时,可以从集合中取出来使用
使用remove
直接移除,因为线程只能被一个任务使用
Thread t = linked.removeFirst();
使用完后需要归还
list.add(T);
linked.addLast(T);
JDK1.5之后,JDK中提供了线程池
3、常用方法
java.util.concurrent.Executors
:线程池的工厂类,用来生成线程池
Executors类中的静态方法
static ExecutorService newFixedThreadPool(int nThread)创建一个有指定数量线程的线程池
参数:线程池中包含线程的个数
返回值:ExecutorService接口,返回的是ExecutorService接口的实现类对象,我们可以用ExecutorService接口接收(面向接口编程)
Future<?> submit(Runnable task)提交一个 Runnable 任务用于执行
提交一个Runnable任务用于执行
4、使用步骤
- 使用工厂类Executors里的静态方法newFixedThreadPool生成一个指定线程数量的线程池
- 创建一个类,实现runnable接口,重写run方法,设置线程任务
- 调用ExecutorsService中的submit方法,传递线程任务,开启线程,执行run
- 使用shutdown方法关闭(销毁)线程池,不建议执行