发现问题:
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);
}
}