Java线程池执行任务的具体流程

Java线程池提交线程任务的方法有四个:

  1. java.util.concurrent.ThreadPoolExecutor#execute
  2. java.util.concurrent.AbstractExecutorService#submit(java.util.concurrent.Callable)
  3. java.util.concurrent.AbstractExecutorService#submit(java.lang.Runnable)
  4. java.util.concurrent.AbstractExecutorService#submit(java.lang.Runnable, T)

通过源码可以看到,方法2、3、4最终会被封装成java.util.concurrent.RunnableFuture后,再次调用方法1,只不过会返回一个Future对象,用来获取任务执行结果。

方法3源码:

    public Future<?> submit(Runnable task) {
        if (task == null) throw new NullPointerException();
        RunnableFuture<Void> ftask = newTaskFor(task, null);
        execute(ftask);
        return ftask;
    }

execute(Runnable command)方法执行时会分为三步:
在这里插入图片描述
注意:

  1. 提交一个任务时,不管当前线程池中的线程是否空闲,只要数量小于核心线程数就会创建新线程。
  2. ThreadPoolExecutor是非公平的,比如队列满了之后提交的Runnable可能会比正在排队的Runnable先执行(如果没有达到最大线程数时)。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值