在VC++.NET中,无论是编译得到的,还是嵌入的汇编代码,若出现对al值的引用,都会出现这种问题。
例:
_asm
{
mov eax,0xa9;
}
在此句之后,al的值为0,ah的值也为0,但ax的值为0xa9,eax的值也正常。
经进一步的研究发现,在上述情况下,也有正常的时候,条件是al的值在0x00到0x7F(包括0x7F)之间时,al的值是正常的。
再如编译得到代码的例子:
char a[2];
long lTest=0xF8;
a[0]=(char)lTest;
a[1]=(char)lTest;
结果是:a[0]==0,a[1]==0;
编译后为:
long lTest=0xF8;
mov dword ptr [ebp-0x06],0xF8;//lTest==0xF8
a[0]=(char)lTest;
mov eax,dword ptr [ebp-0x02];//eax==0xF8,al==0,ah==0,ax==0xf8
mov byte ptr [a],al;//al==0,a[0]=0
a[1]=(char)lTest;
mov eax,dword ptr [ebp-0x02];//eax==0xF8,al==0,ah==0,ax==0xf8
mov byte ptr [ebp-0x01],al;//al==0,a[1]==0;
结果就是这样。
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/10752043/viewspace-962457/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/10752043/viewspace-962457/
本文探讨了VC++.NET中对al寄存器值引用时出现的问题,特别是在al值超出0x00至0x7F范围时的表现异常。通过具体示例展示了错误现象,并分析了编译器生成的相关汇编代码。

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



