首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >RecursiveTask<Integer>正确实现

RecursiveTask<Integer>正确实现
EN

Stack Overflow用户
提问于 2016-06-10 03:03:10
回答 1查看 96关注 0票数 1

哪种实现是正确的?

代码语言:javascript
复制
//previous code
leftSum.fork();
...
return (rightSum.compute() + leftSum().join());

代码语言:javascript
复制
return (leftSum.join() + rightSum().compute());

并说它是不正确的,结果是什么呢?

EN

回答 1

Stack Overflow用户

发布于 2016-06-10 03:14:51

第一种方法是正确的,因为你总是需要遵循下一种顺序:

  1. fork()将左边的任务提交到池,以便在asynchronously.
  2. compute()中执行,以便使用当前thread
  3. join()执行右边的任务,使当前线程等待,直到它获得左边(派生的)任务的结果。

第二种方法将使线程在执行其任务之前等待,这样您就失去了并行执行递归任务的好处,因为它们将一个接一个地执行。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37734205

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档