首页 > 代码库 > 【java解惑】使用double进行小数运算
【java解惑】使用double进行小数运算
如下代码:
public class Example002 { public static void main(String args[]) { System.out.println("println:( 2.00 - 1.10) = " + (2.00 - 1.10)); System.out.printf("printf:( 2.00 - 1.10) = %.2f%n", 2.00 - 1.10); System.out.println("BigDecimal:( 2.00 - 1.10) =" + new BigDecimal("2.00").subtract(new BigDecimal("1.10"))); } }
输出结果:
println:( 2.00 - 1.10) = 0.8999999999999999 printf:( 2.00 - 1.10) = 0.90 BigDecimal:( 2.00 - 1.10) =0.90
原因分析: 1.1 这个数字不能被精确表示成为一个 double,因此它被表示成为最接近它的 double 值。该程序从 2 中减去的就是这个值。更根本的问题是:并不是所有的小数都可以用二进制浮点数来精确表示的。要想能够正确打印结果,一种可行的方案如上所示使用printf来格式化。另外一种方案是,使用BigDecimal来提供支持。使用BigDecimal需要注意的是使用字符串的构造函数而不是直接new BigDecimal(double)的构造方式。
另外需要格式化输出的字符串位数可以参考 http://mouselearnjava.iteye.com/blog/1961008
本文出自 “winger” 博客,谢绝转载!
【java解惑】使用double进行小数运算
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。