C语言-浮点数在内存中的存储

目录

C语言-浮点数在内存中的存储

练习

浮点数的存储

浮点数存的过程

浮点数在内存的存储

浮点数取的过程


C语言-浮点数在内存中的存储

常见的浮点数:3.14149、1E10(科学计数法表示形式:1.0*10^10)等,浮点数家族包括:float、double、long double类型

浮点数表示范围:float.h中定义

整数的取值范围:limits.h中定义

类型取值范围
unsigned char(无符号)0~255(或者写成0xff或者UCHAR_MAX) 
short-32767~32767(或者写成SHRT_MIN~SHTR_MAX)
int-2147483647L~2147483647L(或者写成INT_MIN~INT_MAX)
char(有符号)-128~127(或者写成SCHAR_MIN~SCHAR_MAX)
dauble(直接写成DBL_MIN~DBL_MAX)

练习

运行结果

分析:浮点型存入系统,以浮点型的拿出来还是原来的浮点数,而以整形的方式拿出来的时候,拿出来是错的(同一个(浮点\整)数,以(浮点\整)型的方式拿出来,结果不一样)

结论:整形和浮点型的存储方式不同

上半部分代码:

下半部分代码:

浮点数的存储

根据国际标准IEEE(电气和电子工程协会)754,任意一个二进制浮点数V都可以表示成下面的形式

所以浮点数的存储,其实存储的是S,M,E相关的值 

IEEE754规定:

对于32位的浮点数(float),最高的1位存储符号位S,接着的8位存储指数E,剩下的23位存储有效数字M,所以精度较低,叫单精度

对于64位的浮点数(dauble),最高位存储符号位S,接着的11位存储指数E,剩下的52位存储有效数字M,所以精度更高,叫双精度

浮点数存的过程

IEEE754对有效数字M和指数E,还有一些特别的规定。

至于指数E,情况比较复杂

所以不用考虑E特别大或特别小的问题

浮点数在内存的存储

注意:大家在自己举例子的时候,不要举特殊的例子

例如:二进制的0.1就表示0.5了,表示十进制中0.14之类的数值,可能要在后面加好多个0或1才能近似地凑出来,就是无法精确地相等

如果小数点后的位太多,就看导致浮点数在内存中无法精确地保存

如果想了解浮点数的比较,可以去b站搜《C语言深度解剖》——比特蛋哥过程

浮点数取的过程

指数E从内存中取出的时候分为三种情况:

E不全为1也不全为0

E为全0

说明这将会是一个非常小的数,可以表示+-0

E为全1

这是一个非常大的数值,再加上正负号就表示正负无穷大的数字

  • 7
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
### 回答1: 双精度浮点数C语言的一种数据类型,用于存储小数。它的精度比单精度浮点数更高,可以存储更大范围的数值。在C语言,双精度浮点数的关键字是double,它占用8个字节的内存空间,可以表示的数值范围为±2.23e-308~±1.79e+308,精度为15~16位小数。使用双精度浮点数时,需要在数值后面加上字母d或D,例如:3.1415926D。 ### 回答2: C语言双精度浮点数是一种数据类型,通常用于表示具有大范围和高精度需求的浮点数。它在内存占据8个字节(64位),其一部分用于存储数值的符号位,指数位和尾数位。 双精度浮点数可以表示非常大或非常小的数值,其取值范围一般为±1.7E-308到±1.7E+308,精度可以达到15位有效数字。这使得双精度浮点数在科学计算、工程应用等领域非常有用。 双精度浮点数的内部表示遵循IEEE 754标准,其最高位用于表示数值的符号,0表示正数,1表示负数。接下来的11位用于存储指数,用于表示数值的大小,余下的52位用于存储尾数,表示数值的精度。 由于双精度浮点数存储方式是基于二进制的,因此在进行数值计算时可能会出现舍入误差。这是因为某些十进制数无法准确表示为有限位数的二进制数。因此,在使用双精度浮点数进行计算时,需要注意这种舍入误差可能对计算结果的影响。 为了提高计算的性能,C语言提供了一系列的浮点数运算函数,如加法、减法、乘法、除法等。双精度浮点数变量可以通过赋值操作符或预定义的数值常量进行初始化。在程序使用双精度浮点数时,可以使用%lf格式化符进行输入输出。 总之,C语言的双精度浮点数是一种用于表示大范围和高精度浮点数的数据类型。它的内部表示符合IEEE 754标准,并提供了一系列的数值计算函数来处理双精度浮点数。在进行计算时需要注意舍入误差的可能性。 ### 回答3: C语言的双精度浮点数是一种数据类型,用于表示带有小数部分的数值。其关键字为double,占用8个字节(64位)的内存空间。 双精度浮点数的范围非常广泛,可以表示非常大或非常小的数值,通常可达到±10的308次方。这是由于双精度浮点数使用了指数表示法,在内存以一定的形式存储数值。 双精度浮点数的表示形式由三个主要部分组成:符号、指数和尾数。其,符号位用于表示正或负数,占用1位。指数位用于存储数值的指数部分,占用11位。尾数用于存储数值的小数部分,占用52位。 C语言浮点数运算使用IEEE 754标准,该标准规定了浮点数的二进制表示和运算方式。浮点数的算术运算包括加、减、乘、除等操作,但其精度有限,可能会导致舍入误差。因此,在比较两个浮点数是否相等时,应该考虑设置一个误差范围。 为了提高程序的效率和可靠性,需要注意浮点数的精度问题和浮点数计算的舍入误差。同时,可以使用C语言的数学函数库来执行更复杂的浮点数计算,如三角函数、指数函数等。 总之,C语言的双精度浮点数提供了一种有效的方式来处理带有小数部分的数值,其范围广泛且精度可控,但需要注意数字的精度问题和舍入误差。在实际应用,要根据需要选择合适的数据类型来处理浮点数的运算。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值