什么是线程池
顾名思义,事先创建若干个可执行的线程放入到一个容器中,需要的时候从容器中直接获取线程而不用创建线程,使用完毕放回容器中而不用销毁,从而避免人为创建和销毁线程,提高了效率。
创建线程池
在Java中有一个工具类 Executors ,它提供了几种创建线程池的方法:
newSingleThreadExecutor()
创建一个单一线程的线程池,单线程串行执行所有任务。如果当前任务因为异常结束,那么下一个新的线程会替代它,然后继续顺序执行下去。
newFixedThreadPool(int n)
创建一个固定大小的线程池,每次提交任务就会创建一个线程,直到到达最大大小。一旦达到最大大小,线程池的大小就不会再改变,某个线程如果发生异常,那么就会添加一个新的线程加入到线程池中。
newCachedThreadPool()
创建一个可以缓存的线程池,如果这个线程池的大小超过了当前任务的数量,那么线程池就会回收部分空闲线程,当任务数量增加时,线程池就会增加新线程来处理任务。线程池大小依赖于JVM能创建的最大线程数。
newScheduledThreadPool()
创建一个可以定时或周期执行任务的无大小限制的线程池。
使用线程池的好处
降低资源消耗
重用已经创建的线程,降低线程创建、销毁造成的消耗
提高响应速率
任务到达时,不再等到线程创建就可以运行
提高管理性
线程是稀缺资源,无限制的创建会降低系统的稳定性,使用线程池可以统一分配、调优、监控。