Double的精度问题

一段代码记住一个Java精度计算实数类:

/**
*@author 修炼到救赎
*@date 2016-03-19 0:00
*BigDecimal类的加减乘除方法申明:
*public BigDecimal add(BigDecimal augend);
*public BigDecimal subtract(BigDecimal subtrahend);
*public Bigdecimal multiply(BigDecimal multiplicand);
*public Bigdecimal divide(Bigdecimal divisor);
*/

public class AccuratelyFloat{
    public static void main (String[]args){
        double money=3;
        double price=1.1;
        System.out.println("不精确的计算");
        System.out.println(money-price);
        //精确浮点的解决办法
        BigDecimal money0 = new BigDecimal("3");
        BigDecimal price0 = new  BigDecimal("1.1");
        BigDecimal result = money0.subtract(price0);
        System.out.println("精确计算");
        System.out.println(result); 
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值