为啥 mov/cmp 而不是 cmp 有两个内存操作数? [复制]
Posted
技术标签:
【中文标题】为啥 mov/cmp 而不是 cmp 有两个内存操作数? [复制]【英文标题】:Why mov/cmp instead of cmp with two memory operands? [duplicate]为什么 mov/cmp 而不是 cmp 有两个内存操作数? [复制] 【发布时间】:2021-08-04 16:39:28 【问题描述】:我在查看二进制搜索程序代码时遇到了以下语句
l1: mov si,low_
cmp si,high_
为什么我们需要将 low_ 存储在 si 中,然后与 high_ 进行比较? 不能直接写cmp low_,high_
【问题讨论】:
大多数 x86 指令最多只支持一个内存操作数。 你试过了吗?你的汇编器会告诉你“内存操作数太多”。 先试一下,再问这里.. 【参考方案1】:你不能写cmp low_, high_
。
对于此类问题,请始终参考官方说明说明,例如在https://www.felixcloutier.com/x86/cmp。注意cmp
有cmp r/m16, r16
的形式,其中第一个操作数可以是寄存器或内存,第二个必须是寄存器;以及 cmp r16, r/m16
是相反的。但是没有像cmp r/m16, r/m16
或cmp m16, m16
这样的东西。所以cmp low_, high_
会尝试汇编一条不存在的指令,而您的汇编器会拒绝它。
大多数 x86 算术指令都是这种情况:其中一个操作数可能是内存引用,但不能同时是两者。要对内存中的两个值进行操作,您必须先将其中一个加载到寄存器中,就像这段代码一样。
【讨论】:
以上是关于为啥 mov/cmp 而不是 cmp 有两个内存操作数? [复制]的主要内容,如果未能解决你的问题,请参考以下文章
为啥 LibreOffice Impress 在每次按键时显示两个项目,而不是每个项目一个?