n 个double相加的问题

 先看下面的例子:

public class Test
{

	public static void main(String[] args)
	{
		

		double sum=0;
		double temp=0.38;
		for(int i=0;i<10;i++)
		{
			sum=sum+temp;
			System.out.println("sum:"+sum);
			System.out.println(sum);
		}
		
	}

}


 

程序运行后打印出下面的结果:

 

sum:0.38
0.38
sum:0.76
0.76
sum:1.1400000000000001
1.1400000000000001
sum:1.52
1.52
sum:1.9
1.9
sum:2.28
2.28
sum:2.6599999999999997
2.6599999999999997
sum:3.0399999999999996
3.0399999999999996
sum:3.4199999999999995
3.4199999999999995
sum:3.7999999999999994
3.7999999999999994

 

这并不是我们需要的结果,为啥会这样呢?

Java中的简单浮点数类型float和double不能够进行运算。不光是Java,在其它很多编程语言中也有这样的问题。在大多数情况下,计算的结果是准确的,但是多试几次(可以做一个循环)就可以试出类似上面的错误。现在终于理解为什么要有BCD码了。  
  这个问题相当严重,如果你有9.999999999999元,你的计算机是不会认为你可以购买10元的商品的。  
  在有的编程语言中提供了专门的货币类型来处理这种情况,但是Java没有。现在让我们看看如何解决这个问题。

public class Test
{

	public static void main(String[] args)
	{
		

		double sum=0;
		double temp=0.38;
		for(int i=0;i<10;i++)
		{
		  <SPAN style="COLOR: #ff0000">  BigDecimal b1=new BigDecimal(Double.toString(sum));
                                    BigDecimal b2=new BigDecimal(Double.toString(temp));
</SPAN>                                    sum=b1.add(b2).doubleValue();								}
		    System.out.println("sum"+sum);	
	}

}


sum:0.38
sum:0.76
sum:1.14
sum:1.52
sum:1.9
sum:2.28
sum:2.66
sum:3.04
sum:3.42
sum:3.8

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值