unsigned char 与 char 有什么却别?何时适用
一、在C中,默认的基础数据类型均为signed,如定义变量为int,long等,都为有符号的。如果要定义无符号类型,必须显式地在变量类型前加unsigned。
二、char与unsigned char
1、相同点:在内存中都是一个字节,8位(2^8=256),都能表示256个数字
2、不同点:char的最高位为符号位,因此char能表示的数据范围是-128~127,unsigned char没有符号位,因此能表示的数据范围是0~255
3、实际使用中,如普通的赋值,读写文件和网络字节流都没有区别,不管最高位是什么,最终的读取结果都一样,在屏幕上面的显示可能不一样。
扩展资料:
1、但是要把一个char类型的变量赋值给int、long等数据类型或进行类似的强制类型转换时时,系统会进行类型扩展,这时区别就大了。对于char类型的变量,系统会认为最高位为符号位,然后对最高位进行扩展,即符号扩展。
2、若最高位为1,则扩展到int时高位都以1填充。对于unsigned char类型的变量,系统会直接进行无符号扩展,即0扩展。扩展的高位都以0填充。所以在进行类似的操作时,如果char和unsigned char最高位都是0,则结果是一样的,若char最高位为1,则结果会大相径庭。
3、char*是有符号的,如果大于127即0x7F的数就是负数了,使用%x格式化输出,系统自动进行了符号扩展,就会产生变化。
4、所以在涉及到类型提升的上下文中,要注意使用char*和unsinged char*的区别。
参考资料来源:百度百科--unsigned char
作为字符使用时,都是存储字符的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才会有所区别。
但是对于很多双字节的语音,需要两个char来表示一个字
第一个char的值就会大于127,需要unsigned char来表示,或者是负值的char
char为无符号8位数,,0-255