本质上两种类型都占一个字节。
作为字符使用时,都是存储字符的ASCII码。
比如:unsigned char uc='a';char c='a';printf("%d %d",uc,c);结果为: a
a作为整数使用时,两种类型的取值范围就不同了。
unsigned char 可取0至255,而char可取-128至+127。
比如:unsigned char uc=255;char c=255;printf("%d %d",uc,c);结果为: 255 -1
原因是没有用unsigned修饰的char类型系统将其存储的一个字节值(8位2进制)看作为一个有符号数来处理,最高位为0时,表示正数,为1时表示负数,表示负数时的值为余下7位二进制每一位取反后整体+1。
比如上例中:char c=255; 表面看来超过了char的范围,但系统并不是这样处理的。系统将十进制数255转为二进制数11111111进行存储。
在计算或打印时,发现最高位为1,是负数,余下7位1111111取反后为0000000,加1后为0000001,转为十进制数等于1,最后系统当作-1看待。
所以此时按整数打印c时,输出为-1。总的来说,系统最终存储的都是二进制数11111111,只是在参与运算或显示的时候,unsigned char和char才会有所区别。