一、 线程池是什么
线程池(Thread Pool)构造参数有8个,但是最核心的是3个:corePoolSize核心数、maximumPoolSize最大线程数,workQueue任务列表,它们最大程度地决定了线程池的任务分配和线程分配策略。
线程分为用户级线程和内核级线程,内核级线程是可以调度cpu进行操作的。线程池一方面可以避免创建和销毁线程开销的代价,另一方面因为JVM所创建的每个用户级线程通过库调度器产生对应的内核级线程,使用线程池可以保证安全性,以及提高对系统内核的充分利用。
-
降低资源消耗:通过池化技术重复利用已创建的线程,降低线程创建和销毁造成的损耗。
-
提高响应速度:任务到达时,无需等待线程创建即可立即执行。
-
提高线程的可管理性:使用线程池可以进行统一的分配、调优和监控。如果无限制创建线程,不仅会消耗系统资源,还会因为线程的不合理分布导致资源调度失衡,降低系统的稳定性。
-
提供更多更强大的功能:线程池具备可拓展性,允许开发人员向其中增加更多的功能。比如延时定时线程池ScheduledThreadPoolExecutor,就允许任务延期执行或定期执行。
线程池分类:
1. newFixedThreadPool
创建定长线程池,每当提交一个任务就创建一个线程,直到达到线程池的最大数量,这时线程数量不再变化,当线程发生错误结束时&