BigDecimal

1、BigDecimal 负数判断

BigDecimal bigDecimal = bprocurementOrderPojo.getPayableFee();
int num = bigDecimal.signum();

num是 -1, 0, 1,分别表示 负数、零、正数

2、和0比较

paymentLogVo.getRebateAmount().equals(BigDecimal.ZERO)//是否等于0

int r=bigDecimal.compareTo(BigDecimal.ZERO); //和0,ZERO比较
if(r==0) //等于
if(r==1) //大于
if(r==-1) //小于

3、减法运算subtract()

paymentLogVo.getCallAmount().subtract(paymentLogVo.getBenefit())

4、加法运算add()

paymentLogVo.getRebateAmount().add(paymentLogVo.getBenefit())

5、乘法multiply()

bigDecimal1.multiply(bigDecimal2)

6、除法divide()

bigDecimal1.divide(bigDecimal2)

7、绝对值abs()

bigDecimal1.abs()

 8、BigDecimal的舍入模式

BigDecimal.setScale()方法用于格式化小数点
setScale(1)表示保留一位小数,默认用四舍五入方式
setScale(1,BigDecimal.ROUND_DOWN)直接删除多余的小数位,如2.35会变成2.3
setScale(1,BigDecimal.ROUND_UP)进位处理,2.35变成2.4
setScale(1,BigDecimal.ROUND_HALF_UP)四舍五入,2.35变成2.4
setScaler(1,BigDecimal.ROUND_HALF_DOWN)四舍五入,2.35变成2.3,如果是5则向下舍
setScaler(1,BigDecimal.ROUND_CEILING)接近正无穷大的舍入
setScaler(1,BigDecimal.ROUND_FLOOR)接近负无穷大的舍入,数字>0和ROUND_UP作用一样,数字<0和ROUND_DOWN作用一样
setScaler(1,BigDecimal.ROUND_HALF_EVEN)向最接近的数字舍入,如果与两个相邻数字的距离相等,则向相邻的偶数舍入 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值