NO.3 C++中的signed和unsigned
C++内置了4种算术类型,分别为整数,浮点数,单个字符和布尔值。整数,浮点数,单个字符都有带符号和无符号两种类型,布尔值没有。整数和浮点数的带符号和无符号类型很好理解,比如一般书上都有的int 范围 -32700——32700:unsigned int 范围 0——65500。(整数,浮点数默认都是signed。即int, float其实就是signed int 和 signed float)
下面到正题了
先从《c++ primer》上引一段话
”和其他整型不同,char 有三种不同的类型:普通的char ,unsigned char 和signed char。虽然char 有三种不同的类型,但只有两种表示方式。可以使用unsigned char 或者signed char 来表示char 类型。使用那种char 表示方式由编译器决定。“
char 是字符类型。ASCII码一共需要0到127,共128种,signed char 的范围是-127-127或者是-128-127,unsigned char 的范围是0-255这样,signed char 和unsigned char都能.够完成他们本身的任务。char 是实现相关的,可以在gcc编译时加上选项-funsigned-char使char默认为unsigned char 。
字符型有三种类型但是只有两种表示方式,这里要明白,char 和signed char 是不同的类型,虽然在很多时候signed char 是char 的默认选项。
c++中把负值赋给unsigned类型 是合法的,得到的是负值对该类型的取值个数求模侯的值。把-1赋给unsigned char ,结果是255。
那你会说unsigned char 有什么用呢?c++没有内置的byte 数据结构,一般的用
typedef unsigned char byte typedef unsigned char byte
来自定义。
在申请内存,进行位操作的时候使用相当方便。
平时我们使用的时候没有特别要求,只要用char 就可以了。觉得相对底层一些的操作会用到unsigned char 。
补充:软件开发 , C++ ,