看了一下这个方法的说明: Returns a BigDecimal whose value is (this / divisor), and whose preferred scale is (this.scale() - divisor.scale()); if the exact quotient cannot be represented (because it has a non-terminating decimal expansion) an ArithmeticException is thrown. 抛异常应该就是因为它不能找到一个确切的值去表示这个商值。
无穷的十进制扩展,我的理解是无限位数的小数,例如0.33333……,所以1和3也是会报错的 0.5和0.2可以是因为这个商的位数是有限的。 可以用public BigDecimal divide(BigDecimal divisor,int roundingMode)去解决。 例如: BigDecimal a = new BigDecimal(0.5); BigDecimal b = new BigDecimal(0.2); BigDecimal c = a.divide(b,BigDecimal.ROUND_HALF_EVEN); System.out.println(c); 至于为什么报错,我也跟踪了一下BigDecimal的源码,比较麻烦,就没再研究了,呵呵
BigDecimal 使用户能完全控制舍入行为。如果未指定舍入模式,并且无法表示准确结果,则抛出一个异常;建议使用:pubilc BigDecimal divide(BigDecimal divisor, int scale, int roundingMode)
BigDecimal类的主要功能是进行小数的大数计算,而且最重要的是可以精确到指定的四舍五入位数。 如果要进行四舍五入的操作,则必须依靠以下的方法: public BigDecimal divide(BigDecimal divisor,int scale,int roundingMode) scale:表示四舍五入的位数 roundingMode:四舍五入的操作模式,一般用ROUND_HALF_UP以下是例子import java.math.BigDecimal;class MyMath { public static double add(String num1, String num2) { BigDecimal bd1 = new BigDecimal(num1); BigDecimal bd2 = new BigDecimal(num2); return bd1.add(bd2).doubleValue(); } public static double sub(String num1, String num2) { BigDecimal bd1 = new BigDecimal(num1); BigDecimal bd2 = new BigDecimal(num2); return bd1.subtract(bd2).doubleValue(); } public static double mul(String num1, String num2) { BigDecimal bd1 = new BigDecimal(num1); BigDecimal bd2 = new BigDecimal(num2); return bd1.multiply(bd2).doubleValue(); } public static double div(String num1, String num2, int scale) { BigDecimal bd1 = new BigDecimal(num1); BigDecimal bd2 = new BigDecimal(num2); return bd1.divide(bd2, scale, BigDecimal.ROUND_HALF_UP).doubleValue(); } public static double round(double num, int scale) { BigDecimal bd1 = new BigDecimal(num); BigDecimal bd2 = new BigDecimal(1); return bd1.divide(bd2, scale, BigDecimal.ROUND_HALF_UP).doubleValue(); } }public class BigDecimalDemo { public static void main(String[] args) { String num1 = "12345.07891"; String num2 = "3333.5101"; System.out.println("加法操作:" + MyMath.round(MyMath.add(num1, num2), 2)); System.out.println("减法操作:" + MyMath.round(MyMath.sub(num1, num2), 2)); System.out.println("乘法操作:" + MyMath.round(MyMath.mul(num1, num2), 2)); System.out.println("除法操作:" + (MyMath.div(num1, num2, 2))); } }
Returns a BigDecimal whose value is (this / divisor), and whose preferred scale is (this.scale() - divisor.scale()); if the exact quotient cannot be represented (because it has a non-terminating decimal expansion) an ArithmeticException is thrown.
抛异常应该就是因为它不能找到一个确切的值去表示这个商值。
0.5和0.2可以是因为这个商的位数是有限的。
可以用public BigDecimal divide(BigDecimal divisor,int roundingMode)去解决。
例如:
BigDecimal a = new BigDecimal(0.5);
BigDecimal b = new BigDecimal(0.2);
BigDecimal c = a.divide(b,BigDecimal.ROUND_HALF_EVEN);
System.out.println(c);
至于为什么报错,我也跟踪了一下BigDecimal的源码,比较麻烦,就没再研究了,呵呵
如果要进行四舍五入的操作,则必须依靠以下的方法:
public BigDecimal divide(BigDecimal divisor,int scale,int roundingMode)
scale:表示四舍五入的位数
roundingMode:四舍五入的操作模式,一般用ROUND_HALF_UP以下是例子import java.math.BigDecimal;class MyMath {
public static double add(String num1, String num2) {
BigDecimal bd1 = new BigDecimal(num1);
BigDecimal bd2 = new BigDecimal(num2);
return bd1.add(bd2).doubleValue();
} public static double sub(String num1, String num2) {
BigDecimal bd1 = new BigDecimal(num1);
BigDecimal bd2 = new BigDecimal(num2);
return bd1.subtract(bd2).doubleValue();
} public static double mul(String num1, String num2) {
BigDecimal bd1 = new BigDecimal(num1);
BigDecimal bd2 = new BigDecimal(num2);
return bd1.multiply(bd2).doubleValue();
} public static double div(String num1, String num2, int scale) {
BigDecimal bd1 = new BigDecimal(num1);
BigDecimal bd2 = new BigDecimal(num2);
return bd1.divide(bd2, scale, BigDecimal.ROUND_HALF_UP).doubleValue();
} public static double round(double num, int scale) {
BigDecimal bd1 = new BigDecimal(num);
BigDecimal bd2 = new BigDecimal(1);
return bd1.divide(bd2, scale, BigDecimal.ROUND_HALF_UP).doubleValue();
}
}public class BigDecimalDemo {
public static void main(String[] args) {
String num1 = "12345.07891";
String num2 = "3333.5101";
System.out.println("加法操作:" + MyMath.round(MyMath.add(num1, num2), 2));
System.out.println("减法操作:" + MyMath.round(MyMath.sub(num1, num2), 2));
System.out.println("乘法操作:" + MyMath.round(MyMath.mul(num1, num2), 2));
System.out.println("除法操作:" + (MyMath.div(num1, num2, 2)));
}
}
嗯,知道了。问题出在,实例化BigDecimal时,建议使用的是String类型,不用double,这样就可以解决了