博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C语言中的正负数及其输出以及小数
阅读量:4321 次
发布时间:2019-06-06

本文共 1221 字,大约阅读时间需要 4 分钟。

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)将小数赋值给整数类型,就得把小数部分丢掉,只能取整数部分,这会改变数字本身的值。直接丢掉小数部分,不是进行四舍五入

 由于将小数赋值给整数类型会“失真”,所以编译器一般会给出警告,让大家引起注意。 

 

转载于:https://www.cnblogs.com/YuanBo-China/p/10684852.html

你可能感兴趣的文章
spring cloud: Hystrix(六):feign的注解@FeignClient:fallbackFactory(类似于断容器)与fallback方法...
查看>>
CISCO 动态路由(OSPF)
查看>>
vue.js实现移动端长按事件,处理长按事件和click事件冲突,长按安卓机支持震动...
查看>>
个人开发—进度记录(十一)
查看>>
java中JVM的原理
查看>>
php这是一个随机打印输出字符串的例子
查看>>
前端的图片压缩image-compressor(可在图片上传前实现图片压缩)
查看>>
20165309 实验四 Android程序设计
查看>>
团队博客目录
查看>>
linux的启动流程
查看>>
摩尔斯电码(Morse Code)Csharp实现
查看>>
C#NULL条件运算符
查看>>
使用GZIP压缩网页内容(一)
查看>>
《深入浅出MFC》第二章 C++的重要性质
查看>>
关于智能硬件设备shell安全设计
查看>>
homework1
查看>>
3选择结构程序设计
查看>>
Python学习 12day__高级语法
查看>>
关于做产品的一点思考
查看>>
超大地形的处理 (Terrain Visualization)【转自知乎】
查看>>