ThreadPoolExecutor任务调度策略

execute:

 execute方法时暴露给开发者提交任务的方法,这个方法就是整个线程池的入口。当然还有submit类方法,实际上也是调用了execute方法。

public void execute(Runnable command) {
    if (command == null)
        throw new NullPointerException();
    int c = ctl.get();
    if (workerCountOf(c) < corePoolSize) { // 当前worker数量少于corePoolSize,直接开启一个核心线程执行
        if (addWorker(command, true)) // 添加核心线程失败
            return;
        c = ctl.get();
    }
    if (isRunning(c) && workQueue.offer(command)) { // 如果核心池满了,那么会先将任务入队等待
        int recheck = ctl.get(); // 双重状态检验
        if (! isRunning(recheck) && remove(command))
            reject(command);
        else if (workerCountOf(recheck) == 0) // 此时若池中没有线程,则新开启一个线程去队列中取任务
            addWorker(null, false);
    }
    else if (!addWorker(command, false))
        reject(command);
}


addWorker:

 添加工作线程方法,这个方法时ThreadPoolExecutor的核心方法,代码中包含了多处状态检测。添加成功后则运行线程执行任务。

private boolean addWorker(Runnable firstTask, boolean core) {
    retry:
    for (;;) {
        int c = ctl.get();
        int rs = runStateOf(c);

        // Check if queue empty only if necessary.
        if (rs >= SHUTDOWN &&
            ! (rs == SHUTDOWN &&
       
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值