1、符号也是数字的一部分,也要在内存中体现出来。符号只是正负两种情况,用一位(Bit)就足以表示;C语言中规定,把内存的最高位作为符号位。
2、C语言中规定,在符号位中,用0表示正数、用1表示负数。
3、C语言允许我们这样做,如果不希望设置符号位,可以在数据类型前面加上unsigned关键字,
例如:unsigned int b=1002;或 unsigned b=1002;
这样,short、int、long中就没有符号位了,所有的位都用来表示数值,正数的取值范围更大了,这也意味着,使用了unsigned后只能表示正数,不能在表示负数了!加了unsigned的数字称为无符号数未加的数字称为有符号数!
printf不支持以八进制(%0)和十六进制(%x)形式输出有符号数,只有十进制用%d来表示有符号数。用%u来表示无符号数。
4、工作原则:
1)当以有符号数的形式输出时,printf会读取数字所占的内存,并把最高位作为符号位,把剩下的内存作为数值位。
2)当以无符号数的形式输出时,printf也会读取数字所占的内存,并把所有内存都作为数值位对待。
对于一个有符号的正数,它的符号位是0;当按照无符号数的形式读取时,符号位就变成了数值位,但该位恰巧是0而不是1;所以对数值不会产生影响,这就好比在一个数字前面加0,有多少个0都不会影响数字的值。
可以说,“有符号的正数的最高位是0”这个巧合才使得%0和%x输出有符号数时才不会出错!
5、注意:虽然部分编译器支持二进制数字的表示,但是却不能使用printf函数输出二进制,这一点比较遗憾!
若要使输出的八进制或十六进制的前缀也输出,则要在%前加上 # 号。例如:%#0、%#x
6、小数的输出:
%e以指数形式输出float类型,输出结果中的e小写。
%le以指数形式输出double类型,输出结果中的e小写。
1)%g默认最多保留六位有效数字,包括整数部分和小数部分;%f和%e默认保留六位小数,只包括小数部分。
2)%g不会再最后强加0来凑够有效数字的位数,而%f和%e会在最后强加0来凑足小数部分的位数
7、数字的默认类型:对于整数,默认为int类型;对于小数,默认是double类型。
1)在整数后面紧跟l或者L(不区分大小写)表明该数字是long类型
2)在小数后面紧跟f或F表明数字是float类型
8、小数和整数之间的相互赋值:
1)将整数赋值给小数类型,在小数后面加0就可以了,加几个都无所谓哦!
2)将小数赋值给整数类型,就得把小数部分丢掉,只能取整数部分,这会改变数字本身的值。直接丢掉小数部分,不是进行四舍五入!
由于将小数赋值给整数类型会“失真”,所以编译器一般会给出警告,让大家引起注意。