- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想知道为什么 cmp
指令需要特定的参数顺序条件。
例如,我已经尝试过这两种方法。
cmpl %eax, $'A'
cmpl $'A', %eax
第一行返回错误,表示操作数类型不匹配。第二线效果很好。
我浏览了Intel IA-32手册,但它无法回答我的问题。它只是说参数 1 和 2 之间的减法,而不是每个参数应该具有哪些类型。
我想知道为什么第一行代码返回操作数类型不匹配,但第二行却没有。
最佳答案
机器代码指令仅支持带有立即数的指示。如果您没有找到这个,那么您找错地方了。英特尔的第 2 卷手册详细介绍了每条指令的每种可用编码。 Here's an HTML extract of the entry for cmp
.
请记住,程序集限制不是任意的源代码级别选择;而是任意的。它不是像 C++ 这样的语言,它是一种描述机器代码的方式。
大多数 ALU 指令都会写入其目的地(尤其是可追溯到原始 8086 的指令),因此它不可能是立即数。例如sub %eax, $123
显然没有意义。 因此,机器代码格式的一致性/易于解码是没有具有直接“目标”的特殊 cmp
操作码的原因之一。对于汇编语法来说,这也是不规则的,如果汇编器将该操作码映射到相同的 cmp
助记符,而不是不同的反向 cmp 助记符。
相比之下,cmp r/m32, r32
和 cmp r32, r/m32
都存在,因此您可以在任一方向将内存与寄存器进行比较。同样,这与其他 ALU 指令(例如 add
和 sub
)的模式一致,因此这对于机器代码中更“常规”的解码/模式也有意义。
如果您使用 jcc
对结果进行分支,您始终可以交换操作数并使用相反的条件。有时您希望 CF 设置某种方式来提供 adc
或 sbb
,不过,是的,有时这会带来不便。
但这还不足以让 8086 指令集架构师 Stephen Morse 使用少数未使用的操作码之一与 cmp
的立即编码进行反向比较。
有意义的是像 ARM 那样的反向减法或反向比较指令(即 dst = src - dst
而不是 dst -= src
),但 x86 的可变长度机器代码格式意味着只有这么多 1 字节操作码。这可能只是又一条“正常”立即 ALU 指令。
或者实际上还有 5 个操作码,包括 2 个专用字节(如果我们遵循普通 ALU 指令的模式):普通 op r/m8, imm8
, op r/m16, sign_extended_imm8
, op r/m16, imm16
以及 AL,imm8 和 AX,imm16 短格式(没有 ModRM 字节)。我猜想对于非立即操作数,助记符可能是 cmp
的别名,操作数相反,因此我们不需要这 4 个操作码(两个方向上的 8 位和 16 位)。
ARM 后来出现并使用固定宽度的 32 位指令字,因此有相当多的操作码编码空间可用于反向比较和反向减法等有用指令。
关于assembly - 为什么 cmp 指令中的参数顺序很重要?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56205683/
两种符号-cmp +chroma和 -cmp chroma适合我。它们之间有什么区别吗? 我目前的猜测是否定的,因为 all -cmp arguments can be presented in di
我正在实现一个游戏。我有一个状态树和一个基于 set<> 的优先级队列,用于根据成本对状态进行排序。为此,我将 { bool operator()(const State* lhs, const
和有什么区别 extern int (*func)(void); 和 extern int *func(void); 谢谢 最佳答案 extern int (*func)(void); 声明 func
我必须用汇编写一个函数来完成下面的c代码。 int main(){ int hist[26]={0}; int i; charHistogram("This is a string", hist);
我用我想要循环的次数填充ecx,dec重新调整ecx并如果不为零则跳转 到返回:。 现在的问题是,为什么不: cmp ecx, 0jnz back 之前必需的。jnz 如何自动知道跳转时要比较哪个寄存
我的 CMPedometer 没有运行。 运行之前和之后的代码,但它本身不起作用。我没有收到任何警告或异常。我正在真实的 5s 上进行测试。 我尝试过 querydata 和 startpedomet
我使用下面的代码向端点发送 CMP 证书请求: public static void main(String[] args) { try { System.out.pr
我正在使用 gdb 来调试我的代码,仍然是初学者 我想知道如何获取实际地址 例如,给出以下汇编代码: cmp %eax, 0x4(%rbp,%rbx,4) 我想知道与 %eax 进行比较的内容,换句话
所以我尝试练习在 python 中将函数和关键字作为参数传递,但我得到了一个奇怪的结果。我有以下代码: def myeval(f, *args, **kwargs): return f(*ar
我在 x86 处理器中使用 cmp 命令并且工作正常(二进制文件是使用 gcc 生成的)但是在arm cortex a9中使用它时,它没有给出正确的输出(二进制文件是使用交叉gcc生成的) 使用 cm
我收到以下错误: Assembler messages: Error: operand type mismatch for `cmp' 我的代码中唯一的 cmp 是: "cmpl %eax, $15\
我对组装很陌生,现在我想了解如何cmp作品。这是 wiki 中写的内容: cmp arg2, arg1 Performs a comparison operation between arg1 and
我在比较单个单词(2 个字节)时遇到了 CMP 指令的问题。 以下是我的main.asm: [org 0x7c00] mov bx, HELLO_MSG call print_string mov b
我想知道为什么 cmp 指令需要特定的参数顺序条件。 例如,我已经尝试过这两种方法。 cmpl %eax, $'A' cmpl $'A', %eax 第一行返回错误,表示操作数类型不匹配。第二线效果很
问题 以下两条 x86 指令之间有什么(重要的)区别? 39 /r CMP r/m32,r32 Compare r32 with r/m32 3B /r CMP r32,r/m32
我想知道为什么 cmp 指令需要特定的参数顺序条件。 例如,我已经尝试过这两种方法。 cmpl %eax, $'A' cmpl $'A', %eax 第一行返回错误,表示操作数类型不匹配。第二线效果很
所以我正在阅读一些 assembly source code出于学习目的,遇到了一些非常奇怪的事情(或者我可能只是一个新手): .ver: mov al, [redoxfs.header +
cmp file1 file2 当文件相同时不执行任何操作。那么如何在 shell 脚本中打印出相同的文件呢? 最佳答案 如果文件相同,cpm 的退出状态为零,否则为非零。因此,您可以使用类似 cmp
我希望获得 Bash 脚本循环方面的帮助,该循环将显示两个二进制文件之间的所有差异,仅使用 cmp file1 file2 它只显示了我想使用 cmp 的第一个更改,因为它给出了偏移量和每个更改所在的
有人能告诉我 cmp 命令输出中的“行”号代表什么吗?我问这个是因为,首先,我无法在任何地方找到它的解释。其次,我得到了比较一组文件的结果,其中“char”输出相同(如预期)但“line”输出差异很大
我是一名优秀的程序员,十分优秀!