VC++.NET的寄存器al的Bug

王朝vc·作者佚名  2006-01-08
窄屏简体版  字體: |||超大  

在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;

结果就是这样。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航