zoukankan      html  css  js  c++  java
  • java 减法精度缺失_java double类型数据加减操作精度丢失解决方法

    double类型数据加减运算时,会出现精度缺失。

    打个比方

    double number1 = 1;

    double number2 = 0.2;

    double number3 =number1 + number2 ;

    理论上number3会等于1.2;但是在实际的操作过程中会出现1.299999999999这种情况,这就是double类型的数据进行计算时出现精度缺失。

    解决方法是使用java.math.BigDecimal进行计算。

    /**

    * 加法运算

    * @param number1

    * @param number2

    * @return

    */

    public static double addDouble(double number1 , double number2) {

    BigDecimal bigDecimal1 = new BigDecimal(String.valueOf(number1));

    BigDecimal bigDecimal2 = new BigDecimal(String.valueOf(number2));

    return bigDecimal1.add(bigDecimal2).doubleValue();

    }

    /**

    * 减法运算

    * @param number1

    * @param number2

    * @return

    */

    public static double subDouble(double number1, double number2) {

    BigDecimal bigDecimal1 = new BigDecimal(String.valueOf(number1));

    BigDecimal bigDecimal2 = new BigDecimal(String.valueOf(number2));

    return bigDecimal1.subtract(bigDecimal2).doubleValue();

    }

    /**

    * 乘法运算

    * @param number1

    * @param number2

    * @return

    */

    public static double mul(double number1, double number2) {

    BigDecimal bigDecimal1 = new BigDecimal(String.valueOf(number1));

    BigDecimal bigDecimal2 = new BigDecimal(String.valueOf(number2));

    return bigDecimal1.multiply(bigDecimal2).doubleValue();

    }

    /**

    * 除法运算

    * @param num

    * @param total

    * @return

    */

    public static BigDecimal divide(double num, double total) {

    BigDecimal bigDecimal1 = new BigDecimal(String.valueOf(num));

    BigDecimal bigDecimal2 = new BigDecimal(String.valueOf(total));

    return bigDecimal1.divide(bigDecimal2, 2, BigDecimal.ROUND_HALF_UP);;

    }

    ————————————————
    原文链接:https://blog.csdn.net/bzx226948/article/details/105840795

  • 相关阅读:
    Linux权限对文件或者目录的影响
    Linux基础命令chmod(什么是权限?如何设置权限)
    Shell编程——素数的判断
    Shell编程——阶乘
    Shell编程——回文数
    汇编(8253计数器)
    汇编(8255A的工作方式1)
    汇编(8255A的方式0)
    汇编(程序查询方式控制输入输出)
    Shell函数、接受用户输入
  • 原文地址:https://www.cnblogs.com/yangsanluo/p/14597341.html
Copyright © 2011-2022 走看看