Java练习:double精度丢失问题

具体问题如下:

public class DoubleTest {
	public static void main(String[] args)
	{
		System.out.println(0.05+0.01);
	}
}

输出

0.060000000000000005

解决办法使用BigDecimal 类创建对象进行算法运算。如下:

import java.math.BigDecimal;

public class DoubleTest {
	public static void main(String[] args)
	{
		System.out.println(0.05+0.01);
		BigDecimal a = new BigDecimal("0.05");
		BigDecimal b = new BigDecimal(0.05);
		BigDecimal c = new BigDecimal("0.01");
		BigDecimal d = new BigDecimal(0.01);
		System.out.println(`a.add(c)`);
		System.out.println(b.add(d));
	}
}

输出为:

0.060000000000000005
0.06
0.06000000000000000298372437868010820238851010799407958984375

在第二个输出为a.add(c)第三个输出为b.add(d)
两者的差别即在于在使用BigDecimal类构建对象是采用的构造参数是double浮点数还是String对象。
以上可以看到在使用该类构建实例时一定要使用String构造参数。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值