c语言的带符号扩展和无符号扩展

始终记住两条:

1. 有符号的数据类型,在向高精度扩展时,总是带符号扩展

2. 无符号的数据类型,在向高精度扩展时,总是无符号扩展

char   ca=128;

unsigned  char  ucb=128;

unsigned  short   usc=0;

usc=ca + ucb; 

	printf("%x",usc);

usc=ca +(unsigned  short)ucb; 

	printf("%x",usc);

usc=(unsignedchar)ca + ucb;

	printf("%x",usc);

usc=ca+(char)ucb;

	printf("%x",usc);

那么上面的四种情况分别输出什么呢?

分析:

1)对于char类型,有符号,128已经溢出了,其二进制是 1000 0000,第一位会被当成符号位,

也是就是说此时它是负数了,它扩展成unsigned short时,带符号位扩展,符号位为1,所以在

前方补1,结果是 1111 1111 1000 000。 ucb类型为nsigned char,无符号,二进制是1000 0000,

扩展成unsigned shor,无符号扩展,所以补0,结果是0000 0000 1000 0000,。相加结果为 

1 0000 0000 0000 0000 由于unsigned short是二字节,舍弃最前面的1,所以得到0x0,

2)情况和1一样,只是将ucb显示强制转换为unsigned short,所以得到0x0,

3)ca先强制转换为unsignedchar,仍然是1000 0000,注意此时转换后已经是一个无符号数,

所以再往unsigned  short 扩展时,为无符号扩展,结果为0000 0000 1000 0000,ucb扩展后

也是0000 0000 1000 0000,相加结果为 0000 0001 0000 0000,所以结果为0x100

4)ca转为unsigned short,带符号扩展,为1111 1111 1000 000,ucb先强制转换为char,

然后再转为unsigned short,此时也要带符号扩展,所以也是1111 1111 1000 000,两数相加,

得到 1 1111 1111 0000 0000 ,所以结果为0xff00


你可能感兴趣的:(C/C++)