Java并发编程 ----- Executors框架

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