- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我使用 JAVA ExecutorService 来并行我的任务。有 48 个可用处理器,每个处理器有 12 个核心。所以我想我可以同时启动超过 500 个线程 (500 > 12 * 48)。
这里是详细信息
processor : 47
vendor_id : GenuineIntel
cpu family : 6
model : 85
model name : Intel(R) Xeon(R) Gold 5118 CPU @ 2.30GHz
stepping : 4
microcode : 0x2000043
cpu MHz : 999.985
cache size : 16896 KB
physical id : 1
siblings : 24
core id : 11
cpu cores : 12
apicid : 55
initial apicid : 55
fpu : yes
fpu_exception : yes
cpuid level : 22
wp : yes
我尝试并行执行以下任务。代码看起来像,
int numThread = 500;
ExecutorService executorService = Executors.newFixedThreadPool(numThread);
long startParallel = System.currentTimeMillis();
List<Callable<List<Integer>>> callableTasks = new ArrayList<>();
for (int i = 0; i < numThread; i++) {
final int startTupleIndex = i * batchSize;
final int endTupleIndex = (i + 1) * batchSize;
callableTasks.add(() -> {
List<Integer> batchResult = new ArrayList<>();
long start = System.currentTimeMillis();
for (int j = startTupleIndex; j < endTupleIndex; j++) {
//Some evaluation function
}
long end = System.currentTimeMillis();
System.out.println("index from "+startTupleIndex+" to "+endTupleIndex+" ,time from "
+start+" to "+end+", duration " + (end - start) +"ms");
return batchResult;
});
}
List<Future<List<Integer>>> results = executorService.invokeAll(callableTasks);
for (Future<List<Integer>> result : results)
validTuples.addAll(result.get());
} catch (InterruptedException | ExecutionException e) {
e.printStackTrace();
}
executorService.shutdown();
long endParallel = System.currentTimeMillis();
System.out.println("total ms:"+ (endParallel - startParallel));
但是不同线程的启动时间差别很大。
index from 144978 to 217467 ,time from 1537729372817 to 1537729372984, duration 167ms
index from 1159824 to 1232313 ,time from 1537729372819 to 1537729372985, duration 166ms
index from 1377291 to 1449780 ,time from 1537729372819 to 1537729372987, duration 168ms
index from 434934 to 507423 ,time from 1537729372818 to 1537729372990, duration 172ms
index from 942357 to 1014846 ,time from 1537729372819 to 1537729372992, duration 173ms
index from 579912 to 652401 ,time from 1537729372818 to 1537729372993, duration 175ms
index from 724890 to 797379 ,time from 1537729372818 to 1537729372996, duration 178ms
...
index from 34794720 to 34867209 ,time from 1537729374532 to 1537729374733, duration 201ms
index from 36099522 to 36172011 ,time from 1537729374627 to 1537729374733, duration 106ms
index from 36172011 to 36244344 ,time from 1537729374628 to 1537729374734, duration 106ms
index from 35302143 to 35374632 ,time from 1537729374563 to 1537729374741, duration 178ms
index from 35882055 to 35954544 ,time from 1537729374619 to 1537729374741, duration 122ms
index from 35447121 to 35519610 ,time from 1537729374579 to 1537729374742, duration 163ms
index from 35157165 to 35229654 ,time from 1537729374551 to 1537729374745, duration 194ms
index from 35737077 to 35809566 ,time from 1537729374595 to 1537729374746, duration 151ms
index from 35519610 to 35592099 ,time from 1537729374594 to 1537729374747, duration 153ms
index from 35374632 to 35447121 ,time from 1537729374587 to 1537729374747, duration 160ms
index from 35664588 to 35737077 ,time from 1537729374595 to 1537729374748, duration 153ms
index from 35592099 to 35664588 ,time from 1537729374595 to 1537729374751, duration 156ms
index from 35809566 to 35882055 ,time from 1537729374619 to 1537729374752, duration 133ms
total ms:1939.
问题是每个线程大约需要200ms完成,但总运行时间需要超过1900ms。任务启动时间大致从1537729372817到1537729374628不等。但是有超过500个可用的物理核心。为什么这些任务不能同时启动?非常感谢。
最佳答案
在 executorservice 上调用 invokeAll 后,无法保证所有任务的执行将同时开始。线程调度是高度操作系统特定的,你唯一可以依赖的是你不能依赖诸如“线程何时真正启动”、“它将运行多长时间”之类的东西......以Java的线程状态“Runnable”为例:
“准备运行的线程将转移到可运行状态。在这种状态下,线程可能实际上正在运行,也可能随时准备运行。线程调度程序有责任为线程提供运行时间。”
https://www.geeksforgeeks.org/lifecycle-and-states-of-a-thread-in-java/
关于Java线程启动延迟,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52470104/
每当我运行命令以将 Virtualbox 驱动程序启动 Minishift 到操作系统主机时,它都需要一段疯狂的时间,而且它永远不会结束。有时我什至收到有关达到存储限制的错误消息。 不知道是不是描述h
您好,我正在使用 npm 运行一个基本的 React 项目,我正尝试在 docker 容器中启动它。但是我实际上无法让项目运行。我的 dockerfile 看起来像这样: FROM node:7.8.
所以我想从我的 SSH 终端开始游戏。 这真的很奇怪,当我直接从 Linux GUI 执行此操作时,它可以工作。但是当我使用 SSH 客户端进行远程连接时,它就崩溃了。似乎与我的显示驱动程序有关。 U
我有一个显示图像的动态壁纸。我在 Activity 中更改了该图像。然后我需要通知动态壁纸,以便它知道重新加载资源。 Intent 似乎是完美、简单的解决方案: Intent intent = new
我有一个似乎无法解决的问题。我在 Boot Dashboard 中使用 STS 3.9.2 从 Eclipse (Oxygen) 启动 Spring Boot 应用程序没有任何问题: 但是,当我尝试从
全新的 Python,在我开始摆弄东西之前先设置和安装东西。我的理解是 Python 2.7 和 Python 3.3 之间存在一些显着差异/不兼容,尽管这两个版本都得到了很好的使用,所以我认为最好安
在使用了很长时间的 jQuery 之后,我有一个问题,我正在使用 jQuery 模式(样式)编写一个简单的代码, (function(window, undefined) { var jQu
我正在尝试在 spring boot 应用程序下的非 spring 托管类中配置 Autowired。我在 tomcat 服务器下部署的 Web 应用程序下成功运行了这个。但是当我想在 spring
我对 xmonad 完全陌生,但我想开始使用它来提高我的工作效率。 这是我一直在使用的指南(我使用的是 Apple OS X Snow Leopard) http://xmonad.org/tour.
我试图将Spring Boot指南中的Managing Transactions示例扩展到两个数据源,但是@Transaction注释似乎仅对其中一个数据源有效。 在“Application.java
conEmu 有没有办法默认打开多个不同的选项卡? 我看到这个页面解释了如何使用 splits , 我意识到我可以按 Ctrl + T, 1, Enter,但我希望有一种方法可以自动执行此操作! "%
我正在寻找快速而肮脏的答案。我当时脑子一片空白,盯着屏幕看了 12 个小时以上,我想我中枪了。 我想做一个简单的 SignalR 应用程序作为教程。我找到了这个example ,但我不断收到票证未定义
我正在使用 Azure Powershell cmdlet 来启动/停止 VM。 Start-AzureVM [-ServiceName] [-Name] [ ] Stop-AzureVM [-S
我想使用Powershell脚本代码启动/停止iis和mssql 意味着当我运行ps脚本时,我想启动/停止iis和mssql 我在网上搜索了它,发现了一些代码,但按照我的要求无法正常工作 码: $ii
我在 liferay 工作。我们在我们的项目中使用一个模块来创建 liferay 主题。我使用命令 ant -Ddeploy.war=true 将它部署在服务器中。 war 文件在 liferay 部
我想在已安装 Python 2.7 的 Windows XP 计算机上运行 IPython(版本 0.12)。 我通过 Windows 二进制安装程序安装,但安装后 IPython 没有显示在菜单中,
我从创建了自己的简单图片。 FROM python:2.7.11 RUN mkdir /extra/later/ \ && mkdir /yyy 现在,我可以执行以下步骤: docker run
$(document).ready(function () { setTimeout(function() { window.location.reload(); }, 2000); // 2
我刚刚创建了一个帐户 OpenWeatherMap 我想通过城市 ID API 调用获取当前位置的天气: http://api.openweathermap.org/data/2.5/weather?
我注意到,如果我更改 xcasset 中的图像,启动 Storyboard不会更新。 例如,假设您的启动 Storyboard中有一个 UIImage View ,其中包含一个名为“logo”的蓝色图
我是一名优秀的程序员,十分优秀!