类型转换中的符号扩展问题

由窄字节类型(如char)向宽字节类型(如int)转换,会遇到符号位的扩展问题

例如

http://topic.csdn.net/u/20081030/15/aeae3a59-83da-41ba-83e3-9f13f0499fef.html

的例子

long __cdecl atol(const char *nptr)
{
        c=(int)(unsigned char)*nptr++;
while(isspace(c))
{
     ++nptr;
}
}

isspace(int)函数接受整形参数对nptr类型的转换:确保从 *nptr++ 到 c 是进行零扩展而不是符号扩展,保证 c 中存放的是一个unsigned char 所能表示的值。http://topic.csdn.net/t/20061013/16/5080821.html符号扩展导致溢出的例子:

//unsigned
   char a = 0x80;//char的范围是-128~127
printf("%x\n",a);//%x:16进制

printf( "%x\n ",a);实际上就是printf( "%x\n ",(int)a);

a由1一个字节扩展为4个字节。因为char默认为signed,所以编译器将进行符号位扩展
a:   1000   0000
(int)a:   1111   1111   1111   1111   1111   1111   1000   0000  

所以最终结果为 0xffffff80





   

你可能感兴趣的:(c,扩展,编译器)