multithreading - 如何利用 Apple Silicon 上的高性能内核

标签 multithreading macos performance apple-m1

我开发了一个 macOS 应用程序,该应用程序严重依赖多线程(调用中心模拟器)。它在我的 iMac 2019 上运行良好,并很好地填充了所有核心。在我的测试场景中,它模拟了应用程序。 1.4 米奥。总共 100 次迭代中的电话调用,每次迭代作为并行调度队列上的调度项。

Core usage on Intel iMac

现在我购买了一台配备 M1 Apple Silicon 的新 Mac mini,我很想看看该测试机的性能如何发展。嗯,还不错,但没有我想象的那么好:

<表类=“s-表”> <标题> 系统 持续时间 <正文> iMac 2019、英特尔 6 核 i5、3.0 GHz、Catalina macOS 10.15.7 19.95 秒 Mac mini、M1 8 核、Big Sur macOS 11.2、Rosetta2 26.85 秒 Mac mini、M1 8 核、Big Sur macOS 11.2、原生 ARM 17.07 秒

进一步研究后,我注意到在模拟开始时,M1 Mac 的所有 8 个核心都被正确填满,但几秒钟后,只剩下 4 个高效核心被使用。

Core usage on M1 Mac mini

我已阅读 Apple 文档“使用性能和效率核心优化 Apple Silicon”,并仔细检查了迭代的调度队列是否设置正确:

let simQueue = DispatchQueue.global(qos: .userInitiated)

但是没有成功。运行几秒钟后,高性能核心显然不再被利用。我什至尝试将队列的 qos 设置为 .userInteracive也没有帮助。我还用适当的服务质量标记了调度项目,但这并没有改变任何东西。在我看来,其他应用程序(例如 XCode)确实使用高性能内核,甚至更长时间。

有人知道如何强制 M1 Mac 使用高性能内核吗?

最佳答案

“M1 8核心”实际上是“M1 4性能+ 4个省电核心”。我预计它的性能会比 Intel 6 核心高一些,但也不会高很多。您确实看到了,比 6 个英特尔内核快 15%,或者大约与 7 个英特尔内核一样快。当前的 M1 芯片是低端处理器。 “比Intel六核好一点”还是不错的。

您的代码必须在性能核心上运行,否则根本没有机会接近英特尔的性能。在该图中,没有任何信息告诉您使用了哪些核心。

最有可能发生的情况是所有内核开始运行,每个内核都尝试完成八分之一的工作,大约 8 秒后性能内核完成其工作。然后节能核心将其工作转移到性能核心。您只是将图像误解为只有低性能核心在完成工作。

关于multithreading - 如何利用 Apple Silicon 上的高性能内核,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66348801/

相关文章:

performance - 在非整数键上有效地实现记忆化

python - 缩放 float 列表的最快方法

c# - 在某些情况下,最好使用普通的旧 Thread 对象而不是较新的构造之一吗?

c# - 如何保证我的 Async 方法线程安全?

c - 多线程c exe崩溃但不在vs2013调试中

javascript - 如何在 Macbook 的网页上测试捏合事件

ruby - 将 Ruby 打包成独立的 Mac OS X 应用程序?

ios - 如何修复 Xcode 中的线程错误?

Python os.list_dir 停止一级短

Python 多处理性能仅随所用内核数的平方根提高