百科问答小站 logo
百科问答小站 font logo



多核cpu多线程同时执行cmpxchg指令会发生什么? 第1页

  

user avatar   bei-ji-85 网友的相关建议: 
      

拿Intel的CPU作为例子(别的CPU不太了解),手头没有资料,全凭记忆回答:

CPU内部,多个核心之间有一条环形总线,当有某一个核心需要锁住cache的时候,这个总线会通知所有的核心,所以只要有某个核心使用了cmpxchg,那么其它的核肯定都会停下来,不会出现并发的情况。(关于环形总线的信息,看这个:zhihu.com/question/3463

这条总线的带宽非常高,相对延迟会比较小,但锁总线的开销也是很大的,我印象里好像是几十个指令周期的延迟。

所以不会有真正并发的操作,都是分开执行的。




  

相关话题

  如何评价Apple最新的A15 Bionic 仿生处理器(SoC)? 
  如何看待在杨笠代言intel后,intel的11处理器全部拉跨? 
  CPU(为方便讨论,这里仅限32位X86指令)的各种构架,比如奔3,奔4,对纯加法运算速度有帮助吗? 
  如果CPU够强的话GPU可以阉割掉吗? 
  中国没有能力制造中央处理器(CPU),如果超威半导体(AMD)和英特尔商量好在中国卖高价会怎么样? 
  手机处理器芯片上这么多晶体管都是研发人员一个个排布出来的吗? 
  有哪个高手可以解读“世界黑客编程大赛第一名的作品(97年Mekka ’97 4K Intro)”? 
  如何评价英特尔在 2021 架构日正式公布的 Alder Lake 系列处理器? 
  如何评价英伟达在 GTC 2022 正式发布的首款基于 ARM 的 NVIDIA GRACE CPU? 
  不同指令集架构的芯片,是如何去支持基础软件库的? 

前一个讨论
ARM架构怎样设计才能在指令执行性能上超越X86架构?
下一个讨论
汇编下call和ret指令是否有内存屏障的作用?





© 2025-05-17 - tinynew.org. All Rights Reserved.
© 2025-05-17 - tinynew.org. 保留所有权利