xchg命令是如何在cpu层面实现的?

发布于 2022-09-10 17:02:25 字数 224 浏览 14 评论 9

在高级语言当中,实现两个变量的值交换,
要么,用一个临时变量tmp=x,x=y,y=tmp,要3条语句
要么,用异或: x^=y,y^=x,要两条语句。

但是汇编用一个xchg x,y一条语句就搞定了。
这个xchg在cpu层面是如何实现的? (我没有学过组成原理和体系结构),还是说,实际上也是用的临时变量,只不过是在硬件层面?

请高手解释一下哈,非常感谢!

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(9

烟酒忠诚 2022-09-19 10:10:25

回复 9# garyv

    我觉得是不可以没有temp的,至少temp应该是1bit

风为裳 2022-09-19 08:53:17

回复 1# kgisme170

    楼主可以看些讲isa的书籍,我猜测应该是一个clock之后在时序逻辑驱动下两个存储单元内容自动交换了,不需要一个临时存储单元,这个过程并不复杂,连8051都有这种指令而且是单机器周期指令,我觉得实现最复杂的指令是DSP(矩阵,FFT等)和SIMD等类指令

回忆那么伤 2022-09-19 08:24:15

intel手册给的解释是

Operation
TEMP ←  DEST;
DEST ←  SRC;
SRC ←  TEMP;
可以理解为有个临时寄 ...
epegasus 发表于 2010-12-25 17:49

    楼上几位都是高人啊

So尛奶瓶 2022-09-19 08:13:38

intel手册给的解释是

Operation
TEMP ←  DEST;
DEST ←  SRC;
SRC ←  TEMP;
可以理解为有个临时寄 ...
epegasus 发表于 2010-12-25 17:49

    我想,这只是它语意的解释吧,实现不一定的。

未蓝澄海的烟 2022-09-19 02:58:29

intel手册给的解释是

Operation
TEMP ←  DEST;
DEST ←  SRC;
SRC ←  TEMP;
可以理解为有个临时寄存器

紫轩蝶泪 2022-09-19 02:45:36

在高级语言当中,实现两个变量的值交换,
要么,用一个临时变量tmp=x,x=y,y=tmp,要3条语句
要么,用异或 ...
kgisme170 发表于 2010-12-24 09:04

    从数字电路意义上来讲,一般是没有所谓软件上的“临时变量”这么一说的,硬件和软件的思维以及意义是不一样的,软件更加抽象一些,

一枫情书 2022-09-18 15:11:01

硬件就是硬件,不要用软件的思维思考硬件。
  两个寄存器对调,verilog语言:
reg[31:0]r1,r2;
...
cjaizss 发表于 2010-12-25 15:22

当然,这只是硬件上的真正意义上的寄存器的互换,而对于像处理器这么复杂的电路,只要在汇编的语意上保持一致即可,不一定内部真的马上就实现两组触发器对换,可能会拖到之后实现。

薄凉少年不暖心 2022-09-18 07:32:16

在高级语言当中,实现两个变量的值交换,
要么,用一个临时变量tmp=x,x=y,y=tmp,要3条语句
要么,用异或 ...
kgisme170 发表于 2010-12-24 09:04

    硬件就是硬件,不要用软件的思维思考硬件。
  两个寄存器对调,verilog语言:
reg[31:0]r1,r2;
   always@(posedge clk)
   ...
   if(xchg)
   begin
             r1<=r2;
             r2<=r1;
   end
   else
        ...
    对于处理器而言,刚才verilog里的xchg交换信号是前面的电路驱动的结果   
   节选一下,就是一对d触发器组在xchg信号有效的时候,两边的d和q互相“连接”

小…红帽 2022-09-15 17:16:23

我是低手,但我想是有一个临时的寄存器来做这事吧,只不过用硬件实现,而了且把这个临时寄器屏蔽了。这只是我的想法,但不知道lz为什么关心这个问题。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文