Java小知识:线程池如何实现线程复用?

        闲来没事突然想到这个问题,便百度了下想查看具体实现,无果。便自己翻看了下源码,以下是分析过程。

        众所周知,Java内部自带了个线程池实现 ExecutorService (虽然一直被人看不起)。随便找到其中的一个静态方法

    public static ExecutorService newFixedThreadPool(int nThreads) {
        return new ThreadPoolExecutor(nThreads, nThreads,
                                      0L, TimeUnit.MILLISECONDS,
                                      new LinkedBlockingQueue<Runnable>());
    }

        可知 ExecutorService 也只是一个封装,真正的实现还得看 ThreadPoolExecutor。根据推断我们可以首先从 `ThreadPoolExecutor#execute` 找起

    public void execute(Runnable command) {
        if (command == null)
            throw new NullPointerException();
        int c = ctl.get();
        if (workerCountOf(c) < 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);
    }

        读题解,传入的 Runnable 实例最终经过一系列安全检验被传入 addWorker 方法中,继续追踪可以看到实例(firstTask) 被传入 `ThreadPoolLocal#Worker#init` 的有参构造器中,而该 Worker 实例被添加进名为 workers 的哈希表中

         终于是找到正主了!让我们看看这个 Worker 到底是何方神圣,究竟是如何实现线程复用!

private final class Worker extends AbstractQueuedSynchronizer implements Runnable {
    public void run() {
        runWorker(this);
    }
}

        好家伙,原来 Worker 也实现了 Runnable,查看 runWorker 方法可知,当当前任务执行后task置空,Worker 线程调用 getTask 方法从任务队列中获取新任务并执行。至此便实现了一个 Worker 线程执行多个 Runnable 任务的功能。

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值