char与unsigned char本质区别
2016-01-19 13:44
239 查看
在C中,默认的基础数据类型均为signed,现在我们以char为例,说明(signed) char与unsigned char之间的区别。
首先在内存中,char与unsigned char没有什么不同,都是一个字节,唯一的区别是,char的最高位为符号位,因此char能表示-128~127, unsigned char没有符号位,因此能表示0~255,这个好理解,8个bit,最多256种情况,因此无论如何都能表示256个数字。
在实际使用过程种有什么区别呢?
主要是符号位,但是在普通的赋值,读写文件和网络字节流都没什么区别,反正就是一个字节,不管最高位是什么,最终的读取结果都一样,只是你怎么理解最高位而已,在屏幕上面的显示可能不一样。
但是我们却发现在表示byte时,都用unsigned char,这是为什么呢?
首先我们通常意义上理解,byte没有什么符号位之说,更重要的是如果将byte的值赋给int,long等数据类型时,系统会做一些额外的工作。
如果是char,那么系统认为最高位是符号位,而int可能是16或者32位,那么会对最高位进行扩展(注意,赋给unsigned int也会扩展)
而如果是unsigned char,那么不会扩展。
这就是二者的最大区别。
同理可以推导到其它的类型,比如short, unsigned short。等等
具体可以通过下面的小例子看看其区别:
由此可见,最高位若为0时,二者没有区别,若为1时,则有区别了。
首先在内存中,char与unsigned char没有什么不同,都是一个字节,唯一的区别是,char的最高位为符号位,因此char能表示-128~127, unsigned char没有符号位,因此能表示0~255,这个好理解,8个bit,最多256种情况,因此无论如何都能表示256个数字。
在实际使用过程种有什么区别呢?
主要是符号位,但是在普通的赋值,读写文件和网络字节流都没什么区别,反正就是一个字节,不管最高位是什么,最终的读取结果都一样,只是你怎么理解最高位而已,在屏幕上面的显示可能不一样。
但是我们却发现在表示byte时,都用unsigned char,这是为什么呢?
首先我们通常意义上理解,byte没有什么符号位之说,更重要的是如果将byte的值赋给int,long等数据类型时,系统会做一些额外的工作。
如果是char,那么系统认为最高位是符号位,而int可能是16或者32位,那么会对最高位进行扩展(注意,赋给unsigned int也会扩展)
而如果是unsigned char,那么不会扩展。
这就是二者的最大区别。
同理可以推导到其它的类型,比如short, unsigned short。等等
具体可以通过下面的小例子看看其区别:
#include <stdio.h> void f(unsigned char v) { char c = v; unsigned char uc = v; unsigned int a = c, b = uc; int i = c, j = uc; printf("----------------\n"); printf("%%c: %c, %c\n", c, uc); printf("%%X: %X, %X\n", c, uc); printf("%%u: %u, %u\n", a, b); printf("%%d: %d, %d\n", i, j); } int main(int argc, char *argv[]) { f(0x80); f(0x7F); return 0; } 输出结果: ---------------- %c: ?, ? %X: FFFFFF80, 80 %u: 4294967168, 128 %d: -128, 128 ---------------- %c: , %X: 7F, 7F %u: 127, 127 %d: 127, 127
由此可见,最高位若为0时,二者没有区别,若为1时,则有区别了。
相关文章推荐
- 浅析Oracle中char和varchar2的区别
- MySQL中VARCHAR与CHAR格式数据的区别
- c# StringBuilder.Replace 方法 (Char, Char, Int32, Int32)
- 详解C语言中的char数据类型及其与int类型的转换
- MySQL中CHAR和VARCHAR类型演变和详解
- mysql中char与varchar的区别分析
- C语言中的BYTE和char深入解析
- SQL Server数据类型char、nchar、varchar、nvarchar的区别浅析
- Sqlserver中char,nchar,varchar与Nvarchar的区别分析
- 通过sql语句将blob里的char取出来转成数字保存在其它字段
- 深入SQL Server中定长char(n)与变长varchar(n)的区别详解
- char str[] 与 char *str的区别详细解析
- 浅析string 与char* char[]之间的转换
- QString和char以及string之间的赋值详解
- NSString与C字符串之间的相互转换
- MySQL数据库char与varchar的区别分析及使用建议
- MySQL中VARCHAR与CHAR格式数据的区别
- Qsting 与char *的互换
- Qt中QString,char,int,QByteArray之间到转换
- 字符串转换_BSTR/LPSTR/LPWSTR/Char