unsigned int b=0;
b=b-1;
printf("b=%d\n",b);
unsigned char c=0;
c=c-1;
printf("c=%d\n",c);
为什么b=-1;c=255; ?
据我理解,计算机b,c在内存中应该都是全1.并且输出格式都是%d都有符号,所以
1111111.。。都应该表示为-1,为什么c是255??
正是因为是%d,所以才会有这个情况,%d会把参数以整型输出,而255,是1111 1111,它转换为整型,并没有超出整型的表示范围,不会溢出为-1
char只有一个字节,int至少16位
在不同平台char型的不一样,有的编译器是一个字节有的是两个字节,当超出范围是像127+1就是-128了这根他第一位是符号位有关,你好好分析一下他的取值范围是怎么来的问题就迎刃而解了
%d是将参数当成整数,因此会对unsigned char转换成int,c本来就是255,int足够大,转换后不发生溢出,还是255
int main()
{
unsigned char c=0;
c=c-1;
printf("c=%d\n",(char)c);
}
这样会造成c的溢出,才能输出-1
假如int为16bit,第二行得到 b = 2^16 -1,第三行就是强制转换,类似于(int)b ,所以输出-1;而第二个程序,第二行得到 c = 2^8 -1 = 255,强制转换(int)c,得到的就是255