说我得到
EDX = 0xA28
EAX = 0x0A280105
我运行这个 ASM 代码
IMUL EDX
据我了解,仅使用 EAX .. 如果指定了一个操作数
所以在C代码中应该是这样的
EAX *= EDX;
正确的?
在查看调试器之后..我发现EDX
也被改变了。
0x0A280105 * 0xA28 = 0x67264A5AC8
在调试器中
EAX = 264A5AC8
EDX = 00000067
现在,如果您接受答案0x67264A5AC8
并拆分第一个十六进制对,0x67 264A5AC8
您可以清楚地看到为什么EDX
和EAX
是它们的方式。
好的,所以发生了溢出......因为它不能将这么大的数字存储到 32 位中。所以它开始在 EDX 中使用额外的 8 位
但我的问题是我现在如何在 C 代码中执行此操作以获得相同的结果?
我猜它会像
EAX *= EDX;
EDX = 0xFFFFFFFF - EAX; //blah not good with math manipulation like this.