码迷,mamicode.com
首页 > 编程语言 > 详细

Java中小数精确计算

时间:2018-10-08 15:00:25      阅读:239      评论:0      收藏:0      [点我收藏+]

标签:千万   计算   ima   解决问题   比较   int   其他   str   print   

小数精确计算

System.out.println(2.00 -1.10);//0.8999999999999999

 

上面的计算出的结果不是 0.9,而是一连串的小数。问题在于1.1这个数字不能被精确表示为一个double,因此它被表

示为最接近它的double值,该程序从2中减去的就是这个值,但这个计算的结果并不是最接近0.9的double值。


一般地说,问题在于并不是所有的小数都可以用二进制浮点数精确表示。


二进制浮点对于货币计算是非常不适合的,因为它不可能将1.0表示成10的其他任何负次幂。


解决问题的第一种方式是使用货币的最小单位(分)来表示:

System.out.println(200-110);//90

 

第二种方式是使用BigDecimal,但一定要用BigDecimal(String)构造器,而千万不要用 BigDecimal(double)来构造(也不能将float或double型转换成String再来使用BigDecimal(String)来构造,因为在将float或double转换成String时精度已丢失)。
例如new BigDecimal(0.1),
它将返回一个BigDecimal,
也即0.1000000000000000055511151231257827021181583404541015625,
正确使用BigDecimal,程序就可以打印出我们所期

望的结果0.9:

System.out.println(new BigDecimal("2.0").subtract(new BigDecimal("1.10")));// 0.9

 

另外,如果要比较两个浮点数的大小,要使用BigDecimal的compareTo方法。

Java中小数精确计算

标签:千万   计算   ima   解决问题   比较   int   其他   str   print   

原文地址:https://www.cnblogs.com/stevehu1231/p/9753956.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!