BigDecimal使用总结

作者: adm 分类: java 发布时间: 2022-11-24

对于超过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的方向舍入

如果觉得我的文章对您有用,请随意赞赏。您的支持将鼓励我继续创作!