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

【java解惑】使用double进行小数运算

时间:2014-12-15 21:57:27      阅读:266      评论:0      收藏:0      [点我收藏+]

标签: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进行小数运算

标签:java double 小数运算

原文地址:http://imu2008.blog.51cto.com/3844842/1590229

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