java进阶-线程池 - C - 2 - ThreadPoolExecutor类的变量解释

ThreadPoolExecutor 类变量

    private final AtomicInteger ctl = new AtomicInteger(ctlOf(RUNNING, 0));
    private static final int COUNT_BITS = Integer.SIZE - 3;
    private static final int CAPACITY   = (1 << COUNT_BITS) - 1;

    // runState is stored in the high-order bits
    private static final int RUNNING    = -1 << COUNT_BITS;
    private static final int SHUTDOWN   =  0 << COUNT_BITS;
    private static final int STOP       =  1 << COUNT_BITS;
    private static final int TIDYING    =  2 << COUNT_BITS;
    private static final int TERMINATED =  3 << COUNT_BITS;

    // Packing and unpacking ctl
    private static int runStateOf(int c)     { return c & ~CAPACITY; }
    private static int workerCountOf(int c)  { return c & CAPACITY; }
    private static int ctlOf(int rs, int wc) { return rs | wc; }
    

AtomicInteger ctl

ctl是一个AtomicInteger修饰的变量,用来保存2个变量:

  • workerCount: 线程池中活动线程的数量
  • runState:线程池的运行状态

CAPACITY

表示这个类支持设置的最大线程数量,固定值ZZZZZ

workerCount

workerCount占用低29位存线程数,workerCount代表了线程池活动的线程数量,最小数量是0,最大的数量是(1 << COUNT_BITS) - 1 (536870911);

1 << COUNT_BITS :

00000000 00000000 00000000 00000001 --> 00100000 00000000 00000000 00000000

(1 << COUNT_BITS) - 1 :

00100000 00000000 00000000 00000000 --> 00011111 11111111 11111111 11111111

private static int workerCountOf(int c)  { return c & CAPACITY; }

workerCountOf方法是用从ctl中解析出workerCount的值来。由于CAPACITY高3位是000ctl的值与CAPACITY&操作的时候,高3位将被舍弃;由于CAPACITY低29位是全是1&操作会保持原值,这样workerCount的值就从ctl中解析出来了。

runState

runState占用高3位存线程状态,共有5个值:

  • RUNNING(-536870912):接受新任务,并处理队列任务
  • SHUTDOWN(0): 不接受新任务,但会处理队列中的任务
  • STOP(536870912): 不接受新任务,不会处理队列任务,中断正在处理的任务
  • TIDYING(1073741824): 所有任务已结束,workerCount为0,线程过渡到TIDYING状态,将调用terminated()方法
  • TERMINATED(1610612736): terminated()方法已经完成
private static int runStateOf(int c)     { return c & ~CAPACITY; }

runStateOf方法的作用是解析出runState的值。~CAPACITY将反转CAPACITY的值,也就是CAPACITY的高3位全部为1,低29位全部为0。如此ctl & ~CAPACITY 就会送ctl中解析出runState的值。

workers

表示的是所有work的数量,映射到thread概念,就是  所有线程池中正在running的任务 (==running的线程数量) +  等待队列中的排队任务       

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值