深入浅析Java中线程池的原理-创新互联

这篇文章将为大家详细讲解有关深入浅析Java中线程池的原理,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

成都创新互联-专业网站定制、快速模板网站建设、高性价比古城网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式古城网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖古城地区。费用合理售后完善,10余年实体公司更值得信赖。

ThreadPoolExecutor简介

ThreadPoolExecutor是线程池类。对于线程池,可以通俗的将它理解为"存放一定数量线程的一个线程集合。线程池允许若个线程同时允许,允许同时运行的线程数量就是线程池的容量;当添加的到线程池中的线程超过它的容量时,会有一部分线程阻塞等待。线程池会通过相应的调度策略和拒绝策略,对添加到线程池中的线程进行管理。" 

ThreadPoolExecutor数据结构

ThreadPoolExecutor的数据结构如下图所示:

深入浅析Java中线程池的原理

各个数据在ThreadPoolExecutor.java中的定义如下:

// 阻塞队列。
private final BlockingQueue workQueue;
// 互斥锁
private final ReentrantLock mainLock = new ReentrantLock();
// 线程集合。一个Worker对应一个线程。
private final HashSet workers = new HashSet();
// “终止条件”,与“mainLock”绑定。
private final Condition termination = mainLock.newCondition();
// 线程池中线程数量曾经达到过的大值。
private int largestPoolSize;
// 已完成任务数量
private long completedTaskCount;
// ThreadFactory对象,用于创建线程。
private volatile ThreadFactory threadFactory;
// 拒绝策略的处理句柄。
private volatile RejectedExecutionHandler handler;
// 保持线程存活时间。
private volatile long keepAliveTime;

private volatile boolean allowCoreThreadTimeOut;
// 核心池大小
private volatile int corePoolSize;
// 大池大小
private volatile int maximumPoolSize;
 

网站名称:深入浅析Java中线程池的原理-创新互联
本文URL:http://myzitong.com/article/cocpgo.html