众所周知,在数字表达中,数字是可以加上正负号用于分区正负数的。在C语言中也是如此,但是鉴于数字在计算机中的存储方式,就需要一个bit位来存储符号位,如:
//正数
short a1 = -10;
short a2 = -0x2dc9; //十六进制前缀0x
//负数
int b1 = 10;
int b2 = +0174; //八进制前缀0
以int为例,一个int数值长度为4字节,即32bit位:
在C语言中,规定符号位用0表示正数,用1表示负数。
考虑符号位和不考虑符号位,之间相差了一个bit位,那么能表示的数值范围也相差了一倍;故在不需要考虑符号位的情况下(班级的人数、字符的长度等),可以在数据类型前面加上unsigned前缀,例如:
unsigned short a = 12;
unsigned int b = 1002;
unsigned long c = 983452;
这样,这三个数就只能表示正数,数值的范围也就越大了。
【如果是unsigned int,那么可以省略int,即unsigned int a = 100;等价与unsigned a = 100;】
无符号数的输出
将八进制、十进制和十六进制的无符号数输出时,也需要加上对应的格式控制符:
在进行数值输出时,一定要考虑数值的正负以及对应的格式控制符,因为:
当以有符号数的形式输出时,printf()会读取数字在计算机内所占的内存,并把最高位作为符号位,把剩下的作为数值位;
当以无符号数的形式输出时,printf()也会读取其在计算机中占用的内存,并把所有的内存都作为数值位对待;
如果不按照正确的形式输出数值,可能导致数值位与符号位的读取出错,使得输出的数值发生错误!!
#include <stdio.h>
int main()
{
short a = 0100; //八进制
int b = -0x1; //十六进制
long c = 720; //十进制
unsigned short m = 0xffff; //十六进制
unsigned int n = 0x80000000; //十六进制
unsigned long p = 100; //十进制
//以无符号的形式输出有符号数
printf("a=%#ho, b=%#x, c=%ld\n", a, b, c);
//以有符号数的形式输出无符号类型(只能以十进制形式输出)
printf("m=%hd, n=%d, p=%ld\n", m, n, p);
return 0;
}
运行结果:a=0100, b=0xffffffff, c=720m=-1, n=-2147483648, p=100