C语言中char* 与unsigned char* 的区别
-
指针的类型决定了指向的数据的大小和数据的解析方式
-
在涉及到类型提升的上下文中,要注意使用char* 和unsinged char* 的区别。
C语言中char与unsigned char的区别
相同点: 在内存中都是一个字节,8位(2^8=256),都能表示256个数字(-128 ~ 127)或(0 ~ 255)
不同点: char的最高位为符号位,因此char能表示的数据范围是-128 ~ 127,unsigned char没有符号位,因此能表示的数据范围是0~255
实际使用中,如普通的赋值,读写文件和网络字节流都没有区别,不管最高位是什么,最终的读取结果都一样,在屏幕上面的显示可能不一样。
但是要把一个char类型的变量赋值给int、long等数据类型或进行类似的强制类型转换时时,系统会进行类型扩展,这时区别就大了。对于char类型的变量,系统会认为最高位为符号位,然后对最高位进行扩展,即符号扩展。若最高位为1,则扩展到int时高位都以1填充。对于unsigned char类型的变量,系统会直接进行无符号扩展,即0扩展。扩展的高位都以0填充。所以在进行类似的操作时,如果char和unsigned char最高位都是0,则结果是一样的,若char最高位为1,则结果会大相径庭。
C语言中char与unsigned char的区别
- 指针的类型决定了指向的数据的大小和数据的解析方式
char* 是有符号的,如果大于127即0x7F的数就是负数了,使用%x格式化输出,系统自动进行了符号扩展,就会产生变化。
所以在涉及到类型提升的上下文中,要注意使用char* 和unsinged char* 的区别。