请看下面的neg指令测试代码,下面代码已经在VC6环境下测试过:
mov eax, 1
neg eax
//neg指令后,eax 值为 0xFFFFFFFF,同时EFL标识寄存器中CF=1
mov eax, -1
neg eax
//neg指令后,eax 值为 0x00000001,同时EFL标识寄存器中CF=1
mov eax, 0
neg eax
//neg指令后,eax 值为 0x00000000,同时EFL标识寄存器中CF=0
由此可见,neg eax指令 等同于 IMUL eax, -1,即等同于eax乘以-1,根据结果设置CF进位标识,结果为0则CF=0,非0则CF=1。同时分析neg指令的字面意思:“Negative Morphosyntax”,也应该是取负值的意思。一些书上直接说neg指令是对操作数取补运算。这种说法往往让人很迷惑——正数的补数不是自身吗?neg 1 怎么变成了0xffffffff了?由此可见这种说法并不准确。

本文深入解析了NEG指令的功能及其等效于补运算的过程,通过实例展示了其在不同数值上的表现,解释了CF进位标志的设置原理,并澄清了关于补数的常见误解。
6179

被折叠的 条评论
为什么被折叠?



