【发布时间】:2015-03-02 02:52:21
【问题描述】:
我知道还有一些与此类似的其他问题,但我仍然无法理解其中的 () 部分。有人可以为我拼出这个语法吗?谢谢。
【问题讨论】:
-
用 Intel 语法会更容易理解:
cmp [ebx*4 + 0x80498d4], eax
我知道还有一些与此类似的其他问题,但我仍然无法理解其中的 () 部分。有人可以为我拼出这个语法吗?谢谢。
【问题讨论】:
cmp [ebx*4 + 0x80498d4], eax
cmp %eax,0x80498d4(,%ebx,4)
cmp 是比较汇编指令。它通过从左边减去右边的参数来执行两个参数之间的比较,并设置一个 CPU EFLAGS 寄存器。然后可以使用这个 EFLAGS 寄存器进行条件分支/移动等。
第一个参数: `%eax(%eax 寄存器中的值)
第二个参数: 0x80498d4(,%ebx,4)。这读作offset ( base, index, scale ) 在您的示例中,第二个参数的值是内存位置偏移量0x80498d4 + base (which I believe defaults to zero if not included) + value in %ebx register * 4 (scaling factor)。
注意:我认为这里的 base 是空的,默认值为 0。
您可以查看http://docs.oracle.com/cd/E19120-01/open.solaris/817-5477/ennby/index.html,了解有关 Intel x86 汇编指令语法的更多信息。
【讨论】: