- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试了解 fork-join 的工作原理。
维基百科有以下合并排序示例,其中左半部分被 fork ,右半部分由当前线程处理。
mergesort(A, lo, hi):
if lo < hi: // at least one element of input
mid = ⌊(hi - lo) / 2⌋
fork mergesort(A, lo, mid) // process (potentially) in parallel with main task
mergesort(A, mid, hi) // main task handles second recursion
join
merge(A, lo, mid, hi)
然而,我见过的大多数 Java 示例都会 fork 所有子任务并等待其结果:
for (Document document : folder.getDocuments()) {
DocumentSearchTask task = new DocumentSearchTask(document, searchedWord);
forks.add(task);
task.fork();
}
for (RecursiveTask<Long> task : forks) {
count = count + task.join();
}
return count;
维基百科的例子对我来说更有意义,因为线程会做一些有用的事情,而不是阻塞和等待子任务。
另一方面,如果我们 fork 所有任务,我们就可以避免递归并且无法得到 StackOverflowError
。
分割任务的首选方式是什么?为什么?
最佳答案
我想说,首选的方法是以相同的方式 fork 和处理所有子任务。原因如下:
ForkJoinPool
实现了ExecutorService
。请注意,ExecutorService 中的所有方法都是异步的。这是有原因的 - 您通常可以在后台异步生成一些计算,而您的主线程可以在需要计算结果之前执行一些其他有用的工作,例如产生更多异步任务。
这更容易推理。如果您以相同的方式处理所有子问题而不是在任务中引入某种不对称性,那么代码通常看起来会更干净。
不 fork 并在主线程上执行部分计算实际上没有任何优势。如果你fork所有任务然后等待join,那么你的主线程处于等待状态,几乎不消耗任何资源,工作线程可以充分利用处理器。
不过,这更多的是一个偏好问题,而不是一个严格的选择。除了您提到的潜在堆栈溢出之外,它们在功能上是等效的。
我不能代表维基百科作者发言,但我的猜测是,她要么试图让事情变得简单以便于解释,要么她有不太抽象的语言背景,其中 fork /连接不像 Java 那样简单。
<小时/>更新:关于太多线程阻塞,这不是 ForkJoinPool
的问题。正如所解释的here ,ForkJoinPool
的特殊之处在于,工作窃取确实发生在 join
调用中。
关于java - Fork-join: fork 所有子任务或为当前线程留下一个子任务,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37212898/
目前,我在单击我的正文时打开一个新选项卡,但它将焦点更改为子窗口。但我想通过留下窗口来做到这一点,这样弹出窗口就不会被阻止,并且我可以将焦点放在当前窗口上。 以下代码当前正在运行 /** * For
我有一个带有线性渐变的 css 背景图像。 CSS 代码: .footer-about { display: flex; align-items: center; justif
在服务中包含以下代码(假设在快速端点上): async function (res, req, next) { const fetch = require('node-fetch'); awa
我正在使用 IImageList 和 SHGetFileInfo 为任何给定路径提取巨型图标。一旦我有了它,然后我使用 DrawIconEx 将 HICON 渲染到 HBITMAP 中,最终使用 GD
我有图表并计算了网络密度,现在我应该只保留具有最大权重的分支(网络密度的前 10%,例如 200 中权重最大的 20 个分支)。我找不到该怎么做? 最佳答案 这个问题有点令人困惑,因此,如果稍后出现更
我一直在尝试使用 jquery 创建一种效果,当您将鼠标移到一个 div 上时,整个 body 都会移动,并沿着它经过的点留下一条轨迹。我创建了一个可以使整个 body 移动的功能,但我找不到离开轨迹
我想在桌面上显示放大和缩小图标(控件),而仅在移动设备上浏览时显示 gps 图标。我正在使用这个 css https://unpkg.com/leaflet@1.1.0/dist/leaflet.cs
相关代码(索引为数组大小): typedef struct elemento { unsigned long linha; unsigned long coluna; doub
我有一个 div,因此当我单击时,它会切换为展开或缩回。它在所有浏览器上都运行良好,尽管有一点让我很感兴趣。在谷歌浏览器上,当它缩回时,它会在运动中留下细线。 www.rezoluz.com/logi
每当我的应用程序尝试通过调用 CreateDIBSection() 或使用 LR_CREATEDIBSECTION 标志调用 LoadImage() 来创建 DIB 部分时,它似乎都会成功返回。它返回
我想在 Protractor 测试中脱离 Selenium 控制流。 以下是我迄今为止遇到的步骤和问题: 1。逐个测试禁用它 我的第一个想法是使用 SELENIUM_PROMISE_MANAGER 以
我正在构建一个部署在 CentOS 7.2 上的 ASP.Net Core (netcore 1.1) 应用程序。 我有一个通过 System.Diagnostics.Process 调用外部进程(也
我正在为我的网站创建一个聊天小部件。用户将能够输入纯文本 - 没有 html。 为了消除 HTML 标记并允许用户使用“”,我正在接受他们的输入并在用户屏幕的输入上使用 strip_tags() 和输
我是一名优秀的程序员,十分优秀!