BigDecimal使用总结
对于超过16位的大型数字,需要用到Java在java.math包中提供的API类BigDecimal,而且也不是传统的+-*/,而是调用对应的方法。
1.创建对象
使用new的方式创建BigDecimal对象
BigDecimal a = new BigDecimal("100");//字符串构造
另外建议数值运算使用字符串的方式创建对象,因为:
BigDecimal c = new BigDecimal(1.2); System.out.println(c);
JDK的描述:
1、参数类型为double的构造方法的结果有一定的不可预知性。有人可能认为在Java中写入newBigDecimal(0.1)所创建的BigDecimal正好等于 0.1(非标度值 1,其标度为 1),但是它实际上等于0.1000000000000000055511151231257827021181583404541015625。这是因为0.1无法准确地表示为 double(或者说对于该情况,不能表示为任何有限长度的二进制小数)。这样,传入到构造方法的值不会正好等于 0.1(虽然表面上等于该值)。
2、另一方面,String 构造方法是完全可预知的:写入 newBigDecimal(“0.1”) 将创建一个 BigDecimal,它正好等于预期的 0.1。因此,比较而言,通常建议优先使用String构造方法
另外,当你用了非字符串构造创建了一个BigDecimal对象时,如果进行了除运算,当结果有余数的时候会报java.lang.ArithmeticException这个异常——血与泪的教训
2.加减乘除及指定类型返回
//BigDecimal对象中的值相加,然后返回这个对象。 add(BigDecimal) //BigDecimal对象中的值相减,然后返回这个对象。 subtract(BigDecimal) //BigDecimal对象中的值相乘,然后返回这个对象。 multiply(BigDecimal) //BigDecimal对象中的值相除,然后返回这个对象。 divide(BigDecimal) //将BigDecimal对象的数值转换成字符串。 toString() //将BigDecimal对象中的值以双精度数返回。 doubleValue() //将BigDecimal对象中的值以单精度数返回。 floatValue() //将BigDecimal对象中的值以长整数返回。 longValue() //将BigDecimal对象中的值以整数返回。 intValue()
3.四舍五入
//四舍五入保留两位小数 money.setScale(2, RoundingMode.HALF_UP);
3.保留小数
在进行除法运算的时候,针对可能出现的小数产生的计算,必须要多传两个参数
divide(BigDecimal,"保留小数点后几位小数","舍入模式参数")
其中舍入参数:
ROUND_CEILING //向正无穷方向舍入 ROUND_DOWN //向零方向舍入 ROUND_FLOOR //向负无穷方向舍入 ROUND_HALF_DOWN //向(距离)最近的一边舍入,除非两边(的距离)是相等,如果是这样,向下舍入, 例如1.55 保留一位小数结果为1.5 ROUND_HALF_EVEN //向(距离)最近的一边舍入,除非两边(的距离)是相等,如果是这样,如果保留位数是奇数,使用ROUND_HALF_UP,如果是偶数,使用ROUND_HALF_DOWN ROUND_HALF_UP //向(距离)最近的一边舍入,除非两边(的距离)是相等,如果是这样,向上舍入, 1.55保留一位小数结果为1.6,也就是我们常说的“四舍五入” ROUND_UNNECESSARY //计算结果是精确的,不需要舍入模式 ROUND_UP //向远离0的方向舍入