java float计算_Java如何精确计算小数(Float和Double和BigDecimal)

一、浮点计算中发生精度丢失

无论你使用的是什么编程语言,在使用浮点型数据进行精确计算时,你都有可能遇到计算结果出错的情况。

public classFloatTest {public static voidmain(String[] args) {float f1 = 6.6f;float f2 = 1.3f;

System.out.println(f1 +f2);

}

}*************************************结果:7.8999996

二、为何会出现精度丢失

为什么会这样呢? 因为float和double都是浮点数, 都有取值范围,都有精度范围。

计算机只认识0和1,所有类型的计算首先会转化为二进制的计算。我们demo里的6.6是十进制的,计算机不能直接识别,要先编译成二进制,在这个过程中发生了精度丢失。

三、如何使用浮点数进行精确计算

事实上,浮点数并不适合用于精确计算,而适合进行科学计算。这里有一个小知识:既然float和double型用来表示带有小数点的数,那为什么我们不称 它们为“小数”或者“实数”,要叫浮点数呢?因为这些数都以科学计数法的形式存储。当一个数如50.534,转换成科学计数法的形式为5.053e1,它 的小数点移动到了一个新的位置(即浮动了)。可见,浮点数本来就是用于科学计算的,用来进行精确计算实在太不合适了。

如果是计算金额必须是完全精确的计算, 故不能使用double或者float, 有以下两个方法:

1.采用java.math.BigDecimal.---参考:《java 中 BigDecimal 详解》

2.使用int存储金额的分值,显示的时候在转化为元

使用decimal存储类型的缺点

占用存储空间。浮点类型在存储同样范围的值时,通常比decimal使用更少的空间

使用decimal计算效率不高

因为使用decimal时间和空间开销较大,选用int作为数据库存储格式比较合适,可以同时避免浮点存储计算的不精确和decimal的缺点。对于存储数值较大或者保留小数较多的数字,数据库存储结构可以选择bigint,可以同时避免浮点存储计算不精准和DECIMAL精度计算代价高的问题

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值