FockJoinTask 中 invokeAll方法

/*分叉指定集合 tasks 中的所有任务*/
public static <T extends ForkJoinTask<?>> Collection<T> invokeAll(Collection<T>tasks{

        /*类型验证*/
        if (!(tasks instanceof RandomAccess) || !(tasks instanceof List<?>)) {

            /*包含此集合中所有元素的数组*/
            invokeAll(tasks.toArray(new ForkJoinTask<?>[tasks.size()]));
            return tasks;
        }


        /*集合类型强转*/
        @SuppressWarnings("unchecked")
        List<? extends ForkJoinTask<?>> ts =(List<? extends ForkJoinTask<?>>) tasks;

        /*定义了一个可供抛出的异常*/
        Throwable ex = null;

        /*开始从 tasks 中拿具体的任务*/
        int last = ts.size() - 1;

        /*遍历 。。。*/
        for (int i = last; i >= 0; --i) {

            /*把集合中的任务强制转换为 ForkJoinTask*/
            ForkJoinTask<?> t = ts.get(i);

            if (t == null) {

                /*任务为空需要抛出异常*/
                if (ex == null) ex = new NullPointerException();

            }

            /*把每一个分叉出来的子任务安排在线程池中异步执行*/
            else if (i != 0) t.fork();

            /*t.doInvoke() 独自调用一次,
             因为是绕过了前面 fork 那一步的执行, 
             所以这一步的主要目的是手动让其报错*/
            else if (t.doInvoke() < NORMAL && ex == null) ex = t.getException();

        }

        for (int i = 1; i <= last; ++i) {

            ForkJoinTask<?> t = ts.get(i);

            if (t != null) {

                if (ex != null)
                    
                    /*因为中断不是用来控制取消的,所以把对它的线程中断设置为 false*/
                    t.cancel(false);

                /*绕过了上一步正常流程,这一步主要目的也是手动优雅的让他报错*/
                else if (t.doJoin() < NORMAL)

                    ex = t.getException();
            }

        }

        /*如果不为空,说明存在异常*/
        if (ex != null)

            /*抛出*/
            rethrow(ex);

        /*返回任务集合*/
        return tasks;

    }

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值