首页 > 代码库 > java中如果需要精确的计算答案,请避免使用double类型与float类型
java中如果需要精确的计算答案,请避免使用double类型与float类型
double类型与float类型主要用于科学计算与工程计算而设计的,用于二进制浮点计算。对于普通计算通常是结果不准确的,所以对于普通的浮点数的加减法等,解决的方法需要用int,long,BigDecimal来计算。
1.计算出现的问题?
计算结果如下:
显然结果不是我们所需要的。我们需要的结果是:0.88
所以,我们的程序应该这样写:
1 public static void main(String[] args) {2 BigDecimal a=BigDecimal.valueOf(1.29);3 BigDecimal b=BigDecimal.valueOf(0.41);4 System.out.println(a.subtract(b));5 }
最后的结果也是我们需要的结果:
这又长见识了。。。
java中如果需要精确的计算答案,请避免使用double类型与float类型
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。