16得票2回答
ForkJoinTask与CompletableFuture的比较

在Java 8中,有两种启动异步计算的方式-CompletableFuture和ForkJoinTask。它们似乎很相似-甚至CompletableFuture的内部类也继承自ForkJoinTask。 是否有理由选择其中一种? 我能看到的一个关键区别是,CompletableFuture...

14得票2回答
Angular - RxJs ForkJoin如何在出现错误后继续进行多个请求

我正在查询一个 API 端点,但是使用不同的参数进行多次查询。由于某些原因,这些请求中的一些可能会失败并返回 500 错误。如果发生此情况,我仍希望其他请求继续执行,并返回所有成功请求的数据。let terms = []; terms.push(this.category.category);...

14得票2回答
Java分支/合并框架逻辑

这个问题是在另一个问题的回答中作为“副作用”出现的,更多的是好奇而非实际问题。 Java SE 7提供了Oracle所称的“fork/join框架”。这是一种预计上优于其他方法的方式来调度任务到多个处理器。虽然我理解它应该如何工作,但我无法理解它为什么更优秀以及有关抢占式任务执行的声明。 ...

14得票4回答
如何在ForkJoinPool中使用MDC?

在如何在线程池中使用MDC?的基础上,如何在ForkJoinPool中使用MDC?具体来说,如何包装ForkJoinTask以便在执行任务之前设置MDC值?

12得票1回答
Java不使用所有可用的CPU

我有一个需要对一长串输入进行计算的漫长运算。这些计算是相互独立的,所以我想将它们分配给多个CPU进行运算。我正在使用Java 8。 代码的框架看起来像这样:ExecutorService executorService = Executors.newFixedThreadPool(numTh...

12得票1回答
何时应该停止 Spliterator 分割?

我知道设置并行Stream的开销很大,如果项目数量很少或每个项目的处理速度很快,则单线程处理速度会更快。 但是,trySplit()是否存在类似的阈值,即将问题分解为更小的块会适得其反?我想通过类比于归并排序在最小块上切换到插入排序来思考。 如果是这样,那么阈值是否取决于trySplit(...

11得票2回答
按顺序订阅一组可观察对象的数组

这里,我使用了rxjs的forkJoin来并行订阅一个可观察对象数组。但是我想要按顺序一个接一个地订阅它们,最好的解决方案是什么? 以下是我的代码:var observables = []; Observable.forkJoin(observables) .subscribe((...

11得票4回答
Java 7:分支/合并框架

有人能解释一下Fork/Join是什么吗?

10得票1回答
使用自定义池的Java parallelStream()与调用者工作窃取?

通常使用Java 8的parallelStream()时,其结果是通过默认的公共Fork-Join池(即ForkJoinPool.commonPool())执行。 然而,如果任务不是CPU密集型,例如可能大部分时间都在等待IO,则这明显是不可取的。在这种情况下,需要使用一个不同的线程池,该线...

10得票1回答
Akka - 在负载测试期间,forkjoinpool.scan 占用了 20% 的 CPU 时间。

我们在负载测试和扩展 Akka 应用方面取得了一些进展,但在 visualvm 中看到 scala.concurrent.forkjoin.ForkJoinPool.scan() 排名第二,占自身时间的约 20%。"Self time (CPU)" 栏显示的只有其中的一小部分(不到自身时间栏值...