优秀的编程知识分享平台

网站首页 > 技术文章 正文

Java BigDecimal类常用方法大全 高精度数据处理之BigDecimalPS

nanyue 2024-08-25 10:22:37 技术文章 5 ℃

一、在高精度数据处理时

前端:BigNumber.js

后端:BigDecimal

PS:其实还有一种操作就是:金额计算前乘以10000然后进行操作,最后的结果统一除以10000


二、这里简单罗列下其常用方法(数据来源于网络)


2.1、常用的加减乘除


    1.    BigDecimal(String val):构造方法,将String类型转换成BigDecimal类型数据。

    2.    BigDecimal(double val):构造方法,将double类型转换成BigDecimal类型数据。

    3.    BigDecimal(int val):构造方法,将int类型转换成BigDecimal类型数据。

    4.    BigDecimal add(BigDecimal value):加法,求两个BigDecimal类型数据的和。

    5.    BigDecimal subtract(BigDecimal value):减法,求两个BigDecimal类型数据的差。

    6.    BigDecimal multiply(BigDecimal  value):乘法,求两个BigDecimal类型数据的积。

    7.    BigDecimal divide(BigDecimal divisor, 2, BigDecimal.ROUND_UP) : 
        除法,求两个BigDecimal类型数据的商,保留两位小数。

    8.    BigDecimal remainder(BigDecimal divisor):求余数,求BigDecimal类型数据除以divisor的余数。

    9.    BigDecimal max(BigDecimal value):最大数,求两个BigDecimal类型数据的最大值。

    10.    BigDecimal min(BigDecimal value):最小数,求两个BigDecimal类型数据的最小值。

    11.    BigDecimal abs():绝对值,求BigDecimal类型数据的绝对值。
    12.    BigDecimal negate():相反数,求BigDecimal类型数据的相反数。


2.2、常用的四舍五入

只有在作除法运算或四舍五入时才用到舍入模式,有下面这几种:

        
        ROUND_UP :向远离零的方向舍入。舍弃非零部分,并将非零舍弃部分相邻的一位数字加一。 

        ROUND_DOWN :向接近零的方向舍入。舍弃非零部分,同时不会非零舍弃部分相邻的一位数字加一,采取截取行为。

        ROUND_CEILING :向正无穷的方向舍入。如果为正数,舍入结果同ROUND_UP一致;如果为负数,
                       舍入结果同ROUND_DOWN一致。注意:此模式不会减少数值大小。

        ROUND_FLOOR :向负无穷的方向舍入。如果为正数,舍入结果同ROUND_DOWN一致;
                     如果为负数,舍入结果同ROUND_UP一致。注意:此模式不会增加数值大小。

        ROUND_HALF_UP :向“最接近”的数字舍入,如果与两个相邻数字的距离相等,则为向上舍入的舍入模式。
                        如果舍弃部分>= 0.5,则舍入行为与ROUND_UP相同;否则舍入行为与ROUND_DOWN相同。
                        这种模式也就是我们常说的我们的“四舍五入”。

        ROUND_HALF_DOWN :向“最接近”的数字舍入,如果与两个相邻数字的距离相等,则为向下舍入的舍入模式。
                        如果舍弃部分> 0.5,则舍入行为与ROUND_UP相同;否则舍入行为与ROUND_DOWN相同。
                        这种模式也就是我们常说的我们的“五舍六入”。

        ROUND_HALF_EVEN :向“最接近”的数字舍入,如果与两个相邻数字的距离相等,则相邻的偶数舍入。
                        如果舍弃部分左边的数字奇数,则舍入行为与 ROUND_HALF_UP 相同;如果为偶数,则舍入行为与  
      
        ROUND_HALF_DOWN 相同。注意:在重复进行一系列计算时,此舍入模式可以将累加错误减到最小。此舍入模式也称为“银行家舍入法”,
                            主要在美国使用。四舍六入,五分两种情况,如果前一位为奇数,则入位,否则舍去。

        ROUND_UNNECESSARY :断言请求的操作具有精确的结果,因此不需要舍入。如果对获得精确结果的操作指定此舍入模式,则抛出ArithmeticException。




2.3、常用的比较大小

    
    BigDecimal a = new BigDecimal (101);
    BigDecimal b = new BigDecimal (111);
    //使用compareTo方法比较
    //注意:a、b均不能为null,否则会报空指针
    if(a.compareTo(b) == -1){
     System.out.println("a小于b");
    }
    if(a.compareTo(b) == 0){
     System.out.println("a等于b");
    }
    if(a.compareTo(b) == 1){
     System.out.println("a大于b");
    }
    if(a.compareTo(b) > -1){
     System.out.println("a大于等于b");
    }
    if(a.compareTo(b) < 1){
     System.out.println("a小于等于b");
    }



2.4、取小数部分


        BigDecimal bd = new BigDecimal( "23452.4523434" );
        BigDecimal fractionalPart = bd.remainder( BigDecimal.ONE ); 
        // Result: 0.4523434
最近发表
标签列表