关于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);
 }
}

转载于:https://my.oschina.net/visionit/blog/347151

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值