最近在使用float类型来存储小数的时候,我发现了一个问题。
就是明明输入的小数位数不多但是输出的时候总是出现有误差,试了很久没试出来。
类似这样:
而出现这种问题的原因,归根结底是因为我使用的是float(下面简称f)类型来存储了学生的成绩。在计算机存储数字时,一般都是会先把数字转化成二进制来进行计算存储,然而一般除了十进制数的整数和0.5的倍数之外的大多小数,在计算机内部存储转化成二进制时,会出现无限循环小数或者无限不循环小数。当我们使用float类型来存储这些小数的时候,往往就会因为f的精确度不够没有办法完全读取这些小数,就会以近似值的形式输出在屏幕上,这就是为什么我一直没有办法正确输出成绩的原因。
那么如何解决这种情况呢?
有两个办法,一个是对f类型的小数在输出的时候就规定好要输出的小数的位数,像这样:
这个时候输出的结果就比较正常
第二个办法就是把f类型换成精确度更高的类型,比如double或者long类型的(但是精确度更高的代价就是要占用更多的内存空间),像这样:
同时输出要匹配对应类型的%_
这样就可以把小数正常存储起来啦。
感谢阅读
给个三连吧~~~