Java中大小数BigDecimal的加减乘除用法及场景的详细介绍,看完不信你还会报Syntax error on token “+/-/*“, invalid AssignmentOperat异常

在这里插入图片描述

卖个小问题

八大基本数据类型:char byte double int long short boolean float
数值类型有:
4个整数型 byte int long short
2个浮点型 float double
剩余1个字符型 char
1个布尔型 boolean
其中数值类型面临着很大的问题:
我想要小数点后10位参与运算,假设科学家在计算的过程只能精确到小数点后2位,那可是要出大问题的
int取值范围是[-2147483648, 2147483647],也就十个亿的长度,姓马名云和姓马名化腾每天面临的资产数字恐怕是很多个int类型,像这样的情况Java的基本数据类型就无法解决问题了
但是! 金融行业很多软件都是用Java语言所建立的,面临这一问题如何计算呢
同时平时在使用double类型的时候很容易出现的如下的情况
在这里插入图片描述

所以说,double只能供于一些对数值比较不敏感的行业或者场景使用
为此Java提供了BigDecimal对象来解决这一问题,这个对象也叫做大小数

既然是对象类型了,两个数值之间的加减乘除就不仅仅是通过+ - * /来解决了,肯定是通过方法来实现了

BigDecimal的加减乘除用法

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

除法时存在的精度/进位问题

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

BigDecimal divisor : 这个不必多问,就是你的除数
int scale : 这个是获取的数字想保留几位小数
int roundingMode : 这个是获取的数字保留小数后,对后一位小数选取的模式(四舍五入/进位/舍去),但是这个值最大只能是7
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

第三个参数可选的选项 :

BigDecimal.ROUND_DOWN:直接省略多余的小数,比如1.28如果保留1位小数,得到的就是1.2
在这里插入图片描述
BigDecimal.ROUND_UP:直接进位,比如1.21如果保留1位小数,得到的就是1.3
在这里插入图片描述

BigDecimal.ROUND_HALF_UP:四舍五入,2.35保留1位,变成2.4
在这里插入图片描述

BigDecimal.ROUND_HALF_DOWN:四舍五入,2.35保留1位,变成2.3
后边两种的区别就是如果保留的位数的后一位如果正好是5的时候,一个舍弃掉,一个进位。
在这里插入图片描述

BigDecimal 的比较大小用法

在这里插入图片描述
输出结果如下:
在这里插入图片描述
BigDecimal注意事项
1.BigDecial对象本身的值是不可改变的,就像String一样,它的所有操作都会生成一个新的对象,所以说他的方法返回的是一个新的BigDecial对象而不是在它对象本身的值的基础上修改
这里看看源码
在这里插入图片描述
底层其实调用的就是一个静态的add方法,具体如下
在这里插入图片描述

  1. 不要用equals方法来比较BigDecimal对象,只能通过compareTo()和signum()方法
    在这里插入图片描述
    通过源码介绍我们知道scale是值的小数点后的长度而不是值本身

在这里插入图片描述

在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值