BigDecimald简单使用

为什么要用BigDecimal运算

在计算浮点型数据时,往往会存在数据计算失真问题

例1

2.0 - 1.9 应该等于0.1,用float类型赋值运算得出的结果为0.100000024,有问题

例2

1.8 - 1.9 应该等于 -0.1,用double类型赋值得出的结果为-0.09999999999999987,明显有问题

BigDecimal使用

BigDecimal实现加法运算

java 复制代码
    @org.junit.jupiter.api.Test
    public void aaa(){
        BigDecimal d1 = BigDecimal.valueOf(2.0D);
        BigDecimal d2 = BigDecimal.valueOf(1.9D);
        //不设置舍入模式
        BigDecimal d = d1.add(d2);                                          //3.9
        //设置舍入模式,公共的模式,可去MathContext类查看更多
        BigDecimal dd = d1.add(d2, MathContext.DECIMAL32);                  //3.9
        //设置舍入模式,以new方式设置舍入模式
        BigDecimal ddd = d1.add(d2, new MathContext(5));         //3.9
    }

BigDecimal实现减法运算

java 复制代码
    @org.junit.jupiter.api.Test
    public void aaa(){
        BigDecimal d1 = BigDecimal.valueOf(2.0D);
        BigDecimal d2 = BigDecimal.valueOf(1.9D);
        BigDecimal d = d1.subtract(d2);                                             //0.1
        BigDecimal dd = d1.subtract(d2, MathContext.DECIMAL32);                     //0.1
        BigDecimal ddd = d1.subtract(d2, new MathContext(5));            //0.1
    }

BigDecimal实现乘法运算

java 复制代码
    @org.junit.jupiter.api.Test
    public void aaa(){
        BigDecimal d1 = BigDecimal.valueOf(2.0D);
        BigDecimal d2 = BigDecimal.valueOf(1.9111111111111111111111111111111111111111D);
        BigDecimal multiply0 = d1.multiply(d2);                                     //3.82222222222222240
        BigDecimal multiply1 = d1.multiply(d2, MathContext.UNLIMITED);              //3.82222222222222240
        BigDecimal multiply2 = d1.multiply(d2, MathContext.DECIMAL32);              //3.822222
        BigDecimal multiply3 = d1.multiply(d2, MathContext.DECIMAL64);              //3.822222222222222
        BigDecimal multiply4 = d1.multiply(d2, MathContext.DECIMAL128);             //3.82222222222222240
        BigDecimal multiply5 = d1.multiply(d2, new MathContext(2));      //3.8
    }

BigDecimal实现除法运算

java 复制代码
    @org.junit.jupiter.api.Test
    public void aaa(){
        BigDecimal d1 = BigDecimal.valueOf(2.0D);
        BigDecimal d2 = BigDecimal.valueOf(1.00000000);
        //不设置舍入方式及小数位数
        BigDecimal divide0 = d1.divide(d2);                                           //2
        //以RoundingMode设置舍入方式
        BigDecimal divide1 = d1.divide(d2, RoundingMode.HALF_UP);                     //2.0
        //以MathContext设置舍入方式
        BigDecimal divide2 = d1.divide(d2,MathContext.UNLIMITED);                     //2
        //设置小数位数,舍入方式
        BigDecimal divide4 = d1.divide(d2,10, RoundingMode.HALF_UP);            //2.0000000000
    }

BigDecimal求绝对值

java 复制代码
    @org.junit.jupiter.api.Test
    public void aaa(){
        BigDecimal d1 = BigDecimal.valueOf(-2.0123456789D);
        BigDecimal abs = d1.abs();                              //2.0123456789
        BigDecimal abs1 = d1.abs(MathContext.DECIMAL32);        //2.012346
    }

BigDecimal 比较大小

java 复制代码
    @org.junit.jupiter.api.Test
    public void aaa(){
        BigDecimal d1 = BigDecimal.valueOf(-2.0123456789D);
        BigDecimal d3 = BigDecimal.valueOf(-2.0123456789D);
        BigDecimal d2 = BigDecimal.valueOf(-3.0123456789D);
        //用compareTo比较两个BigDecimal的大小->0:等于;1:大于;-1:小于
        int i = d1.compareTo(d2);   //1
        int i2 = d2.compareTo(d1);  //-1
        int i3 = d3.compareTo(d1);  //0
    }
相关推荐
小庞在加油12 分钟前
Apollo源码架构解析---附C++代码设计示例
开发语言·c++·架构·自动驾驶·apollo
yngsqq35 分钟前
netdxf—— CAD c#二次开发之(netDxf 处理 DXF 文件)
java·前端·c#
A了LONE43 分钟前
h5的底部导航栏模板
java·前端·javascript
专注VB编程开发20年1 小时前
各版本操作系统对.NET支持情况(250707更新)
开发语言·前端·ide·vscode·.net
我喜欢就喜欢1 小时前
RapidFuzz-CPP:高效字符串相似度计算的C++利器
开发语言·c++
莫彩1 小时前
【Modern C++ Part7】_创建对象时使用()和{}的区别
开发语言·c++
经典19921 小时前
spring boot 详解以及原理
java·spring boot·后端
星光54221 小时前
飞算JavaAI:给Java开发装上“智能引擎”的超级助手
java·开发语言
June bug1 小时前
【Python基础】变量、运算与内存管理全解析
开发语言·python·职场和发展·测试
醇醛酸醚酮酯1 小时前
Qt项目锻炼——TODO(五)
开发语言·qt