关于Java中的BigDecimal

为什么用BigDecimal

  • 使用float、double及其对应的包装类时,运算精度可能不满足需求
    • float最多只有7位有效数,则其精度为6-7位。
    • double最多只有16位有效数,则其精度为15~16位。
  • 使用float、double及其对应的包装类时,不便于对小数点以后的若干位进行截取四舍五入或相关处理
    所以BigDecimal主要是用来解决误差问题(精度问题)

BigDecimal构造方法

在这里插入图片描述

通过静态方法创建BigDecimal对象

返回值类型方法说明
BigDecimalvalueOf(double val)基于float / double类型的数据创建BigDecimal对象
BigDecimalvalueOf(long val)基于byte/ short / int / long类型的数据创建BiqDecimal对象

BigDecimal常用API

返回值类型方法说明
BigDecimaladd(BigDecimal augend)加法运算
BigDecimalsubtract(BigDecimal subtrahend)减法运算
BigDecimalmultiply(BigDecimal multiplicand)乘法运算
BigDecimaldivide(BigDecimal divisor)除法运算
BigDecimaldivide(BigDecimal divisor, int roundingMode)除法运算
BigDecimaldivide(BiaDecimaldivisor,int scale, int roundinaMode)除法运算
BigDecimalremainder(BigDecimal divisor)求余运算
BigDecimal[]divideAndRemainder(BigDecimal divisor)除并求余运算
BigDecimalmin(BigDecimal val)取最大值运算
BigDecimalmax(BiqDecimal val)取最小值运算

解释:

  • 在调用divide()方法时,使用roundingMode可以设置运算时的舍入模式
  • 使用BigDecimal类中以ROUND为前缀的常量表示
    • 例如: BigDecimal.ROUND_HALF_UP

关于除法运算的roundingMode

常量值说明
ROUND_UP在丢弃非零部分之前始终增加数字(始终对非零舍弃部分前面的数字加1)
ROUND_DOWN在丢弃某部分之前始终不增加数字(从不对舍弃部分前面的数字加1,即截短)
ROUND_CEILING正数时,与ROUND_UP相同,负数时,与ROUND_DOWN相同
ROUND_FLOOR正数时,与ROUND_DOWN相同,负数时,与ROUND_UP相同
ROUND_HALF_UP满足四舍五入时,与ROUND_UP相同,否则,与ROUND_DOWN相同
ROUND_HALF_DOWN满足五舍六入时,与ROUND_UP相同,否则,与ROUND_DOWN相同
ROUND_HALF_EVEN若舍弃部分左侧为奇数,与ROUND_HALE_UP相同,否则,与ROUND_HALE_DOWN相同
ROUND_UNNECESSARY断言请求的操作具有精确的结果,因此不需要舍入

将BigDecimal转换为基本类型

返回值类型方法说明
intintValue()转换为int,可能丢失精度
intintValueExact()转换为int,若丢失精度则抛出ArithmeticException
longlongValue()转换为long,可能丢失精度
longlongValueExact()转换为long,若丢失精度则抛出ArithmeticException
floatfloatValue()转换为float,可能丢失精度
doubledoubleValue()转换为double,可能丢失精度
bytebyteValueExtra()转换为byte,若丢失精度则抛出ArithmeticException
shortshortValueExact ()转换为short,若丢失精度则抛出ArithmeticException

注意:在进行转换之前,应该明确是否会丢失精度,避免转换结果不符合预期!

代码展示

public class BigDecimalDemo {
    public static void main(String[] args) {
        //创建2个基本类型的浮点数
        double d1 = 0.1;
        double d2 = 0.2;
        //计算2个double的和
        System.out.println("两个double求和:");
        System.out.println(d1+d2);//可以发现最后面有误差
        System.out.println();

        //创建BigDecimal
         /**
         * 当原数使用String表示时,使用构造方法创建BIgDecimal对象
         * 当原数使用double表示时,使用静态ValueOf()方法创建BigDecimal对象
         * 当原始使用double表示时,不要使用double作为构造方法来创建BigDecimal
         */
        String s1 = "0.1";
        String s2 = "0.2";
        BigDecimal number1 = new BigDecimal(s1);
        BigDecimal number2 = new BigDecimal(s2);
        //或者
//        BigDecimal number1 = BigDecimal.valueOf(d1);
//        BigDecimal number2 = BigDecimal.valueOf(d2);

        //通过BigDecimal求和
        System.out.println("两个BigDecimal求和:");
        System.out.println(number1.add(number2));
    }
}

小结

  • 使用BigDecimal主要解决基本数据类型运算精度不足的问题
  • 当原数使用String表示时,使用构造方法创建BigDecimal对象;
  • 当原数使用double表示时,使用valueOf()静态方法创建BigDecimal对象;
  • 当需要进行算术运算时,必须使用BigDecimal提供的API;
  • BigDecimal的API几乎包括了你所能想到的所有数值操作:
  • 你可以将Bignteger转换成任何基本数据类型,但可能丢失精度。
    • 在转换之前,应先明确是否可能丢失精度
    • 你不一定需要将结果转换为数值型,使用字符串也可以用于显示或存储

在这里插入图片描述

其他文章

关于java中的BigInteger

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值