ThreadPoolExecutor任务调度策略

本文深入探讨了Java中的ThreadPoolExecutor任务调度策略,包括execute方法作为任务提交的入口,addWorker方法的核心地位以及如何添加工作线程。同时,分析了Worker的runWorker方法如何执行任务,以及线程如何通过getTask方法从任务队列中获取任务,特别是非核心线程的超时策略。
摘要由CSDN通过智能技术生成
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 &&
       
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值