线程池的管理
ThreadPoolExecutor管理线程池
ThreadPoolExecutor 提供各种各样的用户定制线程管理。
线程池的创建,管理
1:创建
/** 当线程池中的线程小于mCorePoolSize,直接创建新的线程加入线程池执行任务,当线程池中的线程数目等于mCorePoolSize,将会把任务放入任务队列BlockingQueue中,当BlockingQueue中的任务放满了,将会创建新的线程去执行,,但是当总线程数大于mMaximumPoolSize时,将会抛出异常,交给RejectedExecutionHandler处理 mKeepAliveTime是线程执行完任务后,且队列中没有可以执行的任务,存活的时间,后面的参数是时间单位
**/ ThreadFactory是每次创建新的线程工厂
/** 参数说明 */
//corePoolSize:线程池维护线程的最少数量.
//maximumPoolSize:线程池维护线程的最大数量
//keepAliveTime :线程池维护线程所允许的空闲时间
//unit: 线程池维护线程所允许的空闲时间的单位
//workQueue: 线程池所使用的缓冲队列
//handler: 线程池对拒绝任务的处理策略
ThreadPoolExecutor mPool = new ThreadPoolExecutor(
mCorePoolSize,
mMaximumPoolSize,
mKeepAliveTime,
TimeUnit.MILLISECONDS,
new LinkedBlockingQueue<Runnable>(),
Executors.defaultThreadFactory(),
new ThreadPoolExecutor.AbortPolicy()
/*new ThreadPoolExecutor.DiscardPolicy()*/);
}
2:线程添加到线程池
mPool.execute(runnable);//通过execute(Runnable)的方法将线程添加到线程池中,任务的执行方法就是 Runnable类型对象的run()方法。
当一个任务通过execute(Runnable)方法欲添加到线程池时:(参考http://www.aichengxu.com/other/4968924.htm)
1:如果此时线程池中的数量小于corePoolSize,即使线程池中的线程都处于空闲状态,也要创建新的线程来处理被添加的任务。
2:如果此时线程池中的数量等于 corePoolSize,但是缓冲队列 workQueue未满,那么任务被放入缓冲队列。
3:如果此时线程池中的数量大于corePoolSize,缓冲队列workQueue满,并且线程池中的数量小于maximumPoolSize,建新的线程来处理被添加的任务。
4:如果此时线程池中的数量大于corePoolSize,缓冲队列workQueue满,并且线程池中的数量等于maximumPoolSize,那么通过 handler所指定的策略来处理此任务。也就是:处理任务的优先级为:核心线程corePoolSize、任务队列workQueue、最大线程maximumPoolSize,如果三者都满了,使用handler处理被拒绝的任务。
5:当线程池中的线程数量大于 corePoolSize时,如果某线程空闲时间超过keepAliveTime,线程将被终止。这样,线程池可以动态的调整池中的线程数。
3.取消任务
/** 取消线程池中某个还未执行的任务 */
public synchronized void cancel(Runnable runn) {
if (mPool != null && (!mPool.isShutdown())
|| mPool.isTerminating()) {
mPool.getQueue().remove(runn);
}
}
4.判断线程池中是否包含任务
public synchronized boolean contains(Runnable runn) {
if (mPool != null && (!mPool.isShutdown()
|| mPool.isTerminating())) {
return mPool.getQueue().contains(runn);
} else {
return false;
}
}
5.立刻关闭线程池
立即关闭线程池,同事正在执行的任务也将会被中断
public void stop() {
if (mPool != null && (!mPool.isShutdown()
|| mPool.isTerminating())) {
mPool.shutdown();
}
}
6.平缓关闭线程池
平缓关闭单任务线程池,但是会确保所有已经加入的任务都将会被执行完毕才关闭
public synchronized void shutdown() {
if (mPool != null && (!mPool.isShutdown()
|| mPool.isTerminating())) {
mPool.shutdownNow();
}
}