关于Double精度丢失的问题

发现问题:

public static void main(String[] args) {

  double a=0.58;

  int b=(int)(a*100);

  System.out.println("double运算:b="+b);

 }

按理说,打印出来的结果应该是58才对,但实际打印出来的结果居然是:

double运算:b=57

于是上网搜索了一下,double运算会出现精度丢失的问题(具体原因可以去网上搜索一下),于是采用了String结合BigDecimal来进行运算,这样可以有效的避免精度丢失问题的出现。

import java.math.BigDecimal;
/**
 * 提供double数值常用运算方法
 * 
 * @author wangwei
 * 
 */
public class DoubleUtils {
 private BigDecimal bd1;
 private BigDecimal bd2;
 /**
  * double相加
  * 
  * @param a
  * @param b
  * @return
  */
 public double sum(double a, double b) {
  bd1 = new BigDecimal(Double.toString(a));
  bd2 = new BigDecimal(Double.toString(b));
  return bd1.add(bd2).doubleValue();
 }
 /**
  * double相减,前者减后者
  * 
  * @param a
  * @param b
  * @return
  */
 public double subtract(double a, double b) {
  bd1 = new BigDecimal(Double.toString(a));
  bd2 = new BigDecimal(Double.toString(b));
  return bd1.subtract(bd2).doubleValue();
 }
 /**
  * double相乘
  * 
  * @param d1
  * @param d2
  * @return double
  */
 public double multiply(double a, double b) {
  bd1 = new BigDecimal(Double.toString(a));
  bd2 = new BigDecimal(Double.toString(b));
  return bd1.multiply(bd2).doubleValue();
 }
 /**
  * double除法
  * 
  * @param d1
  * @param d2
  * @param scale
  *            保留几个小数位
  * @return
  */
 public double divide(double a, double b, int scale) {
  bd1 = new BigDecimal(Double.toString(a));
  bd2 = new BigDecimal(Double.toString(b));
  return bd1.divide(bd2, scale, BigDecimal.ROUND_HALF_UP).doubleValue();
 }
 /**
  * double 返回精度
  * 
  * @param value
  * @param scale
  *            小数点后位数
  * @param roundingMode 
  * @return
  */
 public double round(double value, int scale, int roundingMode) {
  bd1 = new BigDecimal(value);
  bd1 = bd1.setScale(scale, roundingMode);
  return bd1.doubleValue();
 }
 public static void main(String[] args) {
  double a=0.58;
  int b=(int)(a*100);
  System.out.println("double运算:b="+b);
 }
}

你可能感兴趣的:(关于Double精度丢失的问题)