1.线程池的必要性
我们在使用线程的时候,如果并发的线程数量很多,并且每个线程执行任务的时间很短。而我们要频繁地创建线程但这样会大大降低系统的效率,因为频繁创建线程和销毁线程需要耗费很多时间。而使用线程池之后线程可以重复使用,执行完一个任务之后并不被销毁,这样就大大地提高了系统的效率。
2.线程池概念
线程池:就是一个容纳多个线程的容器,线程池中的线程可以反复的使用,省去了频繁创建线程对象的步骤,避免反复创建线程而消耗过多资源。
3.使用线程池的好处
1. 降低资源消耗
减少了创建和销毁线程的操作次数,线程池中的每个工作线程都可以被重复利用,可执行多个任务
2. 提高响应速度
当任务到达时,任务不需要等待线程创建就可以立即执行,节省时间
3.提高线程的可管理性
使用线程池,可以根据系统的承受能力,调整线程池中工作线线程的数目,防止因为消耗过多的内存,而把服务器累趴下(每个线程需要大约1MB内存,线程开的越多,消耗的内存也就越大,最后死机)
4.线程池的使用
// 1.创建一个类,实现Runnable接口,重写run方法,设置线程任务
public class RunnableImpl implements Runnable {
@Override
public void run() {
System.out.println(Thread.currentThread().getName()+"创建了一个新的线程执行");
}
}
public class Demo {
public static void main(String[] args) {
// 2.使用线程池的工厂类Executors里面提供的静态方法newFixedThreadPool生产一个指定线程数量的线程池
ExecutorService es = Executors.newFixedThreadPool(5); //包含5个线程对象
// 创建Runnable实例对象
RunnableImpl r = new RunnableImpl();
// 3.调用ExecutorService中的方法submit,传递线程任务(实现类),开启线程,执行run方法
es.submit( r );
// 再获取个线程对象,调用RunnableImpl中的run()
es.submit( r );
es.submit( r );
// submit方法调用结束后,程序并不终止,是因为线程池控制了线程的关闭。
// 将使用完的线程又归还到了线程池中
// 关闭线程池,不建议使用
service.shutdown();
}
}