1 有符号数在计算机中的存储方式,均已补码表示。
正数的补码即本身,4的补码为0x00000100;
负数的补码为除最高位符号位外,其余位取反加1.因此-4的补码:
0x10000100-->0x11111011->0x11111100 为0xFC。
2 无符号有符号在做运算时,有符号数会自动提升为无符号数。
3 赋值操作时,
UINT8 a =1 ;
INT8 b = -1;//0xFF
a= b;
有符号赋给无符号,同样字节宽不存在溢出问题,因此a值为0xFF;
另外printf("%d");打印,%d是打印有符号的值,容易被混淆,因此直接打印十六进制更直观。
而无符号赋给有符号时,则需要注意溢出的问题,如下代码,d并没有得到预期的0xc8??可是这个打印结果又是怎么出来的呢??
{
unsigned char a = 1;
signed char b = -1;
a = b;
unsigned char c = 200;
signed char d = 40;
d = c;
printf("a is %x b %x %d c %x d %d %x\n",a,b,b,c,d,d);
}
~
打印结果:a is ff b ffffffff -1 c c8 d -56 ffffffc8