当前位置:首页 > 每日看点 > 正文内容

为什么 m1 采用大小核设计却没有 intel 的问题?

卡卷网7个月前 (01-18)每日看点138

简要回答的就是,苹果的全家桶,只要你不强制要求大核心多线程全程占满的调度方式 ..... 你执行普通代码,Apple 不需要你考虑调度问题,然后它那个默认调度吧 .... 就是优先大核心短时高频单线程调度。

其实你要是跑过mac的峰值曲线就不会说出来什么,mac绝大部分情况下都只跑小核心的错误观点了,mac也好Apple家其他产品也好,始终要有一颗大核是绑死在UI线程也就是主线程上面的。

其实比较靠谱的能够确保一定会让自己的程序执行在mac的全部大核心的方式只有一个,"如果需要更精确地控制任务在特定核心上运行,可以使用底层 API(如pthread)来设置线程亲和性(Thread Affinity)。这种方法需要更深入的系统编程知识。"

下文是AI生层代码块

import Foundation // 创建一个线程 var thread: pthread_t? pthread_create(&thread, nil, { _ in // 设置线程亲和性(绑定到大核) var cpuset = pthread_affinity_np_t() pthread_affinity_np_init(&cpuset) // 假设大核是 CPU 0 和 1(具体核心编号需要根据硬件确定) pthread_affinity_np_set(&cpuset, 0) // 绑定到 CPU 0 pthread_affinity_np_set(&cpuset, 1) // 绑定到 CPU 1 // 应用线程亲和性 pthread_setaffinity_np(pthread_self(), MemoryLayout.size(ofValue: cpuset), &cpuset) // 任务逻辑 print("Task running on high-performance core") for i in 0..<10 { print("Task \(i)") } return nil }, nil) // 等待线程完成 pthread_join(thread!, nil)

这样,我们简单看一下,在window平台上使用代码约束程序跑在全部大核心的做法是什么:

package main import ( "fmt" "log" "runtime" "golang.org/x/sys/windows" ) // 绑定当前线程到指定 CPU 核心 func bindThreadToCPU(cpuID int) error { // 获取当前线程句柄 threadHandle := windows.CurrentThread() // 创建 CPU 集合 var cpuSet uint64 cpuSet |= 1 << uint(cpuID) // 将指定 CPU 核心加入集合 // 设置线程的 CPU 亲和性 if err := windows.SetThreadAffinityMask(threadHandle, cpuSet); err != nil { return fmt.Errorf("failed to set thread affinity: %v", err) } return nil } // 绑定到全部大核心 func bindToBigCores(bigCores []int) error { for _, core := range bigCores { if err := bindThreadToCPU(core); err != nil { return err } } return nil } func main() { // 假设大核心编号为 0-7(根据实际硬件配置调整) bigCores := []int{0, 1, 2, 3, 4, 5, 6, 7} // 绑定主线程到大核心 if err := bindToBigCores(bigCores); err != nil { log.Fatalf("Failed to bind to big cores: %v", err) } // 启动多个 Goroutine,每个 Goroutine 绑定到一个大核心 for i := 0; i < runtime.GOMAXPROCS(0); i++ { go func(id int) { if err := bindThreadToCPU(bigCores[id%len(bigCores)]); err != nil { log.Printf("Worker %d failed to bind: %v", id, err) return } // 执行计算密集型任务 performWork() }(i) } // 防止主线程退出 select {} } // 模拟计算密集型任务 func performWork() { for i := 0; i < 100000000; i++ { _ = i * i } }

下文是AI提供的自动执行代码。

有代码常识的大佬看到这段代码应该就明白过来了,Apple是通过所谓的 “亲和性” 控制的,就是,它不是强制的,更强的约束力来自于Apple自己的多线程逻辑,而 Win11,intel呢,很不幸,是程序员使用指令集硬性控制的,这就非常考验程序员在面对密集型任务的时候,对于程序外资源调度程度的把控了。什么叫做性能差和卡死,说穿了就是系统CPU资源分配的不合理,这一点显而易见,强制自己具备调控最高优先级的Apple芯片要比Win11下的intel芯片控制调度合理性方面要容易得多 .....

扫描二维码推送至手机访问。

版权声明:本文由卡卷网发布,如需转载请注明出处。

本文链接:https://www.kajuan.net/ttnews/2025/01/9897.html

分享给朋友:

相关文章

计算机专业不干互联网不热爱技术,还能转行干什么?

转行的思路,无非也就是那几个。我们顺着每个思路,一路捋一遍,基本上,大致可行的方向,也就有了。一、跟对口职业和岗位业务链条相邻的职业和岗位计算机专业如果找到了对口的技术岗位,跟技术工作联系最紧密的岗位是什么?产品经理。当然,大多数产品经理也...

Redmi 为什么可以把性价比做得那么高?

一位修手机的老大哥曾经跟我说过,红米1那个手机,除了处理器还凑活,其余零部件,就是市面上山寨机那种。其实红米性价比并不算极致,而且一直都有竞争者,从原来的群魔乱舞,到后来的荣耀,魅蓝,一加,再到现在的IQOO和realme。红米的方法也很简...

有没有能够兼顾便携并且流畅运行各种AI应用的笔记本?求推荐?

有没有能够兼顾便携并且流畅运行各种AI应用的笔记本?求推荐?

看了下题主的描述,可以考虑「联想YOGA Air 15 Aura AI元启版」,今年9月底出的一款轻薄本,也通过了英特尔Evo严苛认证。处理器用了英特尔最新的「酷睿 Ultra 7 258V」,主要亮点就是AI性能、图形处理能力和能效,很适...

领导给我介绍了私活,挣了3W。该给领导分多少合适呢?

你看,这就是网络的好处了。这种问题,你去问亲戚朋友,一大帮子人有一大帮子说法,还不排除有人眼红故意坑你瞎出主意。你这隔网上一问,大家素昧平生,反而因为想骗个赞跟你使出浑身解数来出主意。多好你看。其实这事道理很简单。人脉是人家的,活是你干的。...

如何评价小米14这款手机?

如何评价小米14这款手机?

本来小米 14 和 14 Pro 是打算放一起拆的,但是因为时间关系,实在凑不到一起了。所以今天给大家补一篇详细的图文拆解,基本信息都有了,如有遗漏可以在评论区留言。双卡上下放置,卡托材质为金属 + 塑料,内侧有防尘防水的胶圈。后盖为玻璃材...

怎样使自己处于高能量状态?

1、不要习惯性的回顾过去那些让你尴尬和犯了错误的事情,不要嫌弃自己蠢。学会原谅自己,当你不断回忆那些错误和囧事的时候,告诉自己:自己确实做错了,下次不要再犯即可,不需一遍遍的回忆。这件事情已经发生,不要再一遍遍的折磨自己,不断回忆一点好处没...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。