java创建线程池

偶尔善良 提交于 2019-11-25 16:53:13

线程池:是拿空间换时间的一种手段;JDK1.5以后加入java.util.concurrent包 线程池有了很大的改观

               例如:用户提交一个请求任务 服务器执行这个任务需要通过三个阶段时间消耗,线程创建的时间,线程执行任务的时间以及销毁线程的时间;而线程池技术主要就是致力于减少线程创建与线程销毁的时间(拿空间换时间)

线程池的作用以及原理:可以根据系统环境 自动或手动设置线程数量 达到运行的最佳效果,少了浪费系统资源,多了造成拥挤效率不高每个线程占用内存大概再1M左右,当一个请求任务提交到服务以后 首先将其放入任务队列,如果此时线程池中有等待的工作线程则会去取任务队列最先进入的任务进行执行,每个工作线程可以被重复利用;这样就可以达到一个控制系统执行线程数量的作用;

线程池中几个比较重要的类:

 Executor  执行线程的工具类

 Executors  生成一些常用线程池的静态工厂

 ExecutorService 真正的线程池接口

 ScheduledExecutorService  能和Timer/TimerTask类似,解决那些需要任务重复执行的问题。

ThreadPoolExecutor   ExecutorService的默认实现。

ScheduledThreadPoolExecutor  继承ThreadPoolExecutor的ScheduledExecutorService接口实现,周期性任务调度的类实现。

要配置一个线程池是比较复杂的,尤其是对于线程池的原理不是很清楚的情况下,很有可能配置的线程池不是较优的,因此在Executors类里面提供了一些静态工厂,生成一些常用的线程池。

1. newSingleThreadExecutor

创建一个单线程的线程池。这个线程池只有一个线程在工作,也就是相当于单线程串行执行所有任务。如果这个唯一的线程因为异常结束,那么会有一个新的线程来替代它。此线程池保证所有任务的执行顺序按照任务的提交顺序执行。

2.newFixedThreadPool

创建固定大小的线程池。每次提交一个任务就创建一个线程,直到线程达到线程池的最大大小。线程池的大小一旦达到最大值就会保持不变,如果某个线程因为执行异常而结束,那么线程池会补充一个新线程。

3. newCachedThreadPool

创建一个可缓存的线程池。如果线程池的大小超过了处理任务所需要的线程,

那么就会回收部分空闲(60秒不执行任务)的线程,当任务数增加时,此线程池又可以智能的添加新线程来处理任务。此线程池不会对线程池大小做限制,线程池大小完全依赖于操作系统(或者说JVM)能够创建的最大线程大小。

4.newScheduledThreadPool

创建一个大小无限的线程池。此线程池支持定时以及周期性执行任务的需求

 

ThreadPoolExecutor的完整构造方法的签名是:ThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, BlockingQueue<Runnable> workQueue, ThreadFactory threadFactory, RejectedExecutionHandler handler) . (以上1,2,3这三种方式都是通过此方法实现的!)

corePoolSize - 池中所保存的线程数,包括空闲线程。

maximumPoolSize-池中允许的最大线程数。

keepAliveTime - 当线程数大于核心时,此为终止前多余的空闲线程等待新任务的最长时间。

unit - keepAliveTime 参数的时间单位。

workQueue - 执行前用于保持任务的队列。此队列仅保持由 execute方法提交的 Runnable任务。

threadFactory - 执行程序创建新线程时使用的工厂。

handler - 由于超出线程范围和队列容量而使执行被阻塞时所使用的处理程序。

ThreadPoolExecutor是Executors类的底层实现。

在JDK帮助文档中,有如此一段话:

“强烈建议程序员使用较为方便的Executors工厂方法Executors.newCachedThreadPool()(无界线程池,可以进行自动线程回收)、Executors.newFixedThreadPool(int)(固定大小线程池)Executors.newSingleThreadExecutor()(单个后台线程)

 

当一个任务提交过来以后 首先判断线程池中corePoolSize  是否有等待的工作线程 如果有则直接提交执行 如果没有则加入队列;

这里队列有三种类型,理解还不深刻 暂时不做详细评论;

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!