C语言中浮点数的精度问题

Python013

C语言中浮点数的精度问题,第1张

如果你输入的时候用%f,那么可能编译能通过,但是会有警告,运行的时候就会出现问题,因为你要是按%f输入一个浮点类型的数,那么存储变量的时候,每个变量会占四个字节,而当你用到变量时,是double类型的,会出去八个字节,这八个字节可能四个是你输入的,剩下的那四个就是属于垃圾数据了,所以不行,而当你用%lf输入时,存储是八个字节,用的时候也是八个字节,所以就没问题了。

浮点数不是连续值,有一定精度,特点是动态范围大。它还没有int的精度高,因为int是32位表示,float只有23位有效值,其他是符号位和指数。

既然计算得不到12.10,就是浮点数不能精确表示12.10。

c

=

12.099998精度也很高了,只差0.000002,差值很小了