Java并发编程 ----- Executors框架
其他
2019-04-23 19:04:50
阅读次数: 0
Executors创建线程池的方法:
1、newFixedThreadPool() 方法,创建一个定长的线程池,该方法返回一个固定数量的线程池,该方法的线程数量始终保持不变,当有任务提交时,若该线程池中有线程空闲,则立即执行,若没有则被暂缓在任务列表中等待空闲线程。
2、newSingleThreadExecutor()方法,创建一个线程的线程池,若线程空闲则执行,若没有,任务则等待。
3、newCachedThreadPoo()方法,创建一个可缓存线程池,返回一个可根据实际情况调整整个线程个数的线程池,不限制最大线程数量,若有空闲的线程则执行,若没有,则创建新的线程来执行任务,并且每一个空闲线程将在60S内进行回收。
4、newScheduledThreadPool()方法,也创建一个定长的线程池,类似于newFixedThreadPool(),区别是定时及周期性任务执行。
当查看其源码实现,它们内部实现均用了ThreadPoolExecutor这个类,所以我们可以使用该类进行自定义线程。
public ThreadPoolExecutor (int corePoolSize,int maxinumPoolSize,long keepAliveTime, TimeUnit unit, BlockingQueue<Runnable> workQueue,ThreadFactory threadFactory,RejectedExecutionHandler handeler){....}
解析:corePoolSize :核心线程(当创建实例时候,初始化线程的数量)
maxinumPoolSize:该线程池中的能创建的最大线程数量
keepAliveTime :线程空闲时候,线程生存的时间
unit :空闲线程生存的时间单位
workQueue: 当没有空闲线程时候,任务被暂存的位置
handeler :当缓存任务也被填满,则需要对外界发出警告,拒绝任务的加入
转载自blog.csdn.net/cheng_zhang_zhong/article/details/89393364