【语句总结】java中数值的精确计算,大型小数:BigDecimal

本文深入讲解Java中的BigDecimal类,涵盖其创建、四则运算及截断操作,特别强调除法运算的细节处理与舍入模式选择,适合需要高精度计算的开发者阅读。

BigDecimal(大型小数)是Java在java.math包中提供的API类,用于精确计算、储存和表示超过16为的数。

如何使用BigDecimal类?

 1. 创建
 2. 运算
 3. 截断(保留位数)

即:
1、创建BigDecimal类来储存数值。
BigDecimal有4中构建方法,各对应一种数据类型。
(1)BigDecimal(int)
(2)BigDecimal(long)//整数
(3)BigDecimal(float)
(4)BigDecimal(double)//浮点数
比如:

...
float Pi=3.1415926;
BigDecimal pai=new BigDecimal(Pi);//构建方法
System.out.println("pai="+pai);
...


结果为:pai=3.1415926,此时pai是一个BigDecimal类,值是3.1415926。

2、BigDecimal的四则远算。

   

 public BigDecimal add(BigDecimal value);//加法
    
 public BigDecimal subtract(BigDecimal value);//减法 
    
 public BigDecimal multiply(BigDecimal value);//乘法
    
 public BigDecimal divide(BigDecimal value);//除法

比如:

 

...
BigDecimal a = new BigDecimal("4.5");
BigDecimal b = new BigDecimal("1.5");
a.add(b);
System.out.println("a + b =" + a);
...

结果是a + b =6.0

注意:
其中,除法divide在使用上有一些细节。
BigDecimal除法如果出现不能整除的情况,比如 4.5/1.3,这时会报错

    java.lang.ArithmeticException: Non-terminating decimal expansion; 
    no exact representable decimal result.

其实divide方法有可以传三个参数:

public BigDecimal divide(BigDecimal divisor, int scale, int roundingMode) 

第一参数表示除数, 
第二个参数表示小数点后保留位数,
第三个参数表示舍入模式,有下面这几种:  

    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的方向舍入:正数向上取整,负数向下取整

3、对BigDecimal进行截断。 

使用BigDecimal.setScale(int 保留位数, 保留方式)方法:

...
BigDecimal a = new BigDecimal("4.5635");
a = a.setScale(3, RoundingMode.HALF_UP);//保留3位小数,且四舍五入,第一个参数可以是变量
System.out.println(a);
...

结果是4.56


截取结尾的0:

...
BidDecimal res=in.nextBigDecimal();
String res = ans.stripTrailingZeros().toPlainString();
//去除后面无用的0比如5.100变为5.1
...

其中,方法toPlainString()的作用是将可能由科学计数法表示的res用小数(字符串)表示,然后再用方法stripTrailingZeros()去除末尾的0。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值