美文网首页
Java 浮点数精确计算

Java 浮点数精确计算

作者: XngPro | 来源:发表于2017-02-17 21:42 被阅读0次

示例代码

public class TestArithmetic {

    public static void main(String[] args) {
        System.out.println("0.09 + 0.01 = " + (0.09 + 0.01));
        System.out.println("9.99 - 0.12 = " + (9.99 - 0.12));
        System.out.println("17.173 * 100 = " + (17.173 * 100));
        System.out.println("16.3 / 1000 = " + (16.3 / 1000));
    }
}

运行结果

0.09 + 0.01 = 0.09999999999999999
9.99 - 0.12 = 9.870000000000001
17.173 * 100 = 1717.2999999999997
16.3 / 1000 = 0.016300000000000002

是不是怀疑以上结果写错了?但是结果确实是这样的,你可以亲自运行以上代码试试。

WHY?

为什么出现这种情况?因为 floatdouble 浮点类型在计算机中是无法准确表示的,例如 0.01 在计算机中只是表示成一个近似值,因此对于浮点数参与运算的结果会出现不准确的情况。

如何解决

使用 BigDecimal 进行精确计算

public class ArithmeticUtils {
    private static final int DEF_SCALE = 10;

    public static double add(double d1, double d2) {
        BigDecimal b1 = new BigDecimal(Double.toString(d1));
        BigDecimal b2 = new BigDecimal(Double.toString(d2));
        return b1.add(b2).doubleValue();
    }

    public static double subtract(double d1, double d2) {
        BigDecimal b1 = new BigDecimal(Double.toString(d1));
        BigDecimal b2 = new BigDecimal(Double.toString(d2));
        return b1.subtract(b2).doubleValue();
    }

    public static double multiply(double d1, double d2) {
        BigDecimal b1 = new BigDecimal(Double.toString(d1));
        BigDecimal b2 = new BigDecimal(Double.toString(d2));
        return b1.multiply(b2).doubleValue();
    }

    public static double divide(double d1, double d2) {
        return divide(d1, d2, DEF_SCALE);
    }

    public static double divide(double d1, double d2, int scale) {
        if (scale < 0) {
            throw new IllegalArgumentException("The scale must be a positive integer or zero");
        }
        BigDecimal b1 = new BigDecimal(Double.toString(d1));
        BigDecimal b2 = new BigDecimal(Double.toString(d2));
        return b1.divide(b2, scale, BigDecimal.ROUND_HALF_UP).doubleValue();
    }
}

再次运行以下代码

public class TestArithmetic {

    public static void main(String[] args) {
        System.out.println("0.09 + 0.01 = " + ArithmeticUtils.add(0.09, 0.01));
        System.out.println("9.99 - 0.12 = " + ArithmeticUtils.subtract(9.99, 0.12));
        System.out.println("17.173 * 100 = " + ArithmeticUtils.multiply(17.173, 100));
        System.out.println("16.3 / 1000 = " + ArithmeticUtils.divide(16.3, 1000));
    }
}

正确结果输出

0.09 + 0.01 = 0.1
9.99 - 0.12 = 9.87
17.173 * 100 = 1717.3
16.3 / 1000 = 0.0163

相关文章

  • Java 浮点数精确计算

    示例代码 运行结果 是不是怀疑以上结果写错了?但是结果确实是这样的,你可以亲自运行以上代码试试。 WHY? 为什么...

  • Awesome Java

    基础 Java 入门与实践 Java 语法清单 Java 8 系列之重新认识 HashMap Java 浮点数精确...

  • MySQL浮点计算存在的问题与解决方案

    在计算机中,浮点数往往很难精确表示,那么浮点数运算结果也往往难以精确表示。MySQL同样也存在这个问题。 解决方案...

  • 第11章 编写精确代码所需编码准则

    11.1 计算机并不如想象得那么精确 数字电路机器无法准确表示小数。 11.2 需要进行精确计算时避开浮点数运算 ...

  • 个人代码库-待更新

    JS 浮点数相加不精确解决 浮点数取两位小数 css 内计算 input 按钮美化(input 上传框美化实例)

  • Java精确计算

    在java.math 的包中有3个class,在这我只举BigInteger的例子 BigDecimal 不可变的...

  • Java基础知识陷阱

    Java浮点数精确运算陷阱 System.out.println(2.0 - 1.1); 以上结果为0.89999...

  • Python3 - 执行精确的浮点数运算

    问题 对浮点数执行精确的计算操作,并且不希望有任何小误差的出现。 解决方案 浮点数的一个普遍问题是它们并不能精确的...

  • 1.2 浮点型运算

    在计算机中,浮点数虽然表示的范围大,但是,浮点数有个非常重要的特点,就是浮点数常常无法精确表示。浮点数在内存的表示...

  • BigDecimal为什么可以精确计算

    为什么浮点数无法精确计算 计算机底层只能用二进制表示数,因此只能精确表示x*2^y类型的数,不能被此形式计算得来的...

网友评论

      本文标题:Java 浮点数精确计算

      本文链接:https://www.haomeiwen.com/subject/brnlwttx.html