BigDecimal除法函数保留⼩数和四舍五⼊
商=被除数/除数
关于有的商是⼩数点后⾯的是舍去还是保留,这个根据项⽬中的要求不⼀样,⽅式也不⼀样,我做了⼀个⼩⼩的总结,下⾯是我算的百分⽐,
double numbe=new BigDecimal((float)a/b).setScale(2, BigDecimal.ROUND_DOWN).doubleValue();
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则向下舍
1、ROUND_UP
舍⼊远离零的舍⼊模式。
在丢弃⾮零部分之前始终增加数字(始终对⾮零舍弃部分前⾯的数字加1)。
注意,此舍⼊模式始终不会减少计算值的⼤⼩。
2、ROUND_DOWN
接近零的舍⼊模式。
在丢弃某部分之前始终不增加数字(从不对舍弃部分前⾯的数字加1,即截短)。
注意,此舍⼊模式始终不会增加计算值的⼤⼩。
3、ROUND_CEILING
接近正⽆穷⼤的舍⼊模式。
如果 BigDecimal 为正,则舍⼊⾏为与 ROUND_UP 相同;
如果为负,则舍⼊⾏为与 ROUND_DOWN 相同。
注意,此舍⼊模式始终不会减少计算值。
4、ROUND_FLOOR
接近负⽆穷⼤的舍⼊模式。
如果 BigDecimal 为正,则舍⼊⾏为与 ROUND_DOWN 相同;
如果为负,则舍⼊⾏为与 ROUND_UP 相同。
注意,此舍⼊模式始终不会增加计算值。
5、ROUND_HALF_UP
向“最接近的”数字舍⼊,如果与两个相邻数字的距离相等,则为向上舍⼊的舍⼊模式。
如果舍弃部分 >= 0.5,则舍⼊⾏为与 ROUND_UP 相同;否则舍⼊⾏为与 ROUND_DOWN 相同。
注意,这是我们⼤多数⼈在⼩学时就学过的舍⼊模式(四舍五⼊)。
6、ROUND_HALF_DOWN
向“最接近的”数字舍⼊,如果与两个相邻数字的距离相等,则为上舍⼊的舍⼊模式。
如果舍弃部分 > 0.5,则舍⼊⾏为与 ROUND_UP 相同;否则舍⼊⾏为与 ROUND_DOWN 相同(五舍六⼊)。bigdecimal除法保留小数
7、ROUND_HALF_EVEN
向“最接近的”数字舍⼊,如果与两个相邻数字的距离相等,则向相邻的偶数舍⼊。
如果舍弃部分左边的数字为奇数,则舍⼊⾏为与 ROUND_HALF_UP 相同;
如果为偶数,则舍⼊⾏为与 ROUND_HALF_DOWN 相同。
注意,在重复进⾏⼀系列计算时,此舍⼊模式可以将累加错误减到最⼩。
此舍⼊模式也称为“银⾏家舍⼊法”,主要在美国使⽤。四舍六⼊,五分两种情况。
如果前⼀位为奇数,则⼊位,否则舍去。
以下例⼦为保留⼩数点1位,那么这种舍⼊⽅式下的结果。
1.15>1.2 1.25>1.2
8、ROUND_UNNECESSARY
断⾔请求的操作具有精确的结果,因此不需要舍⼊。
如果对获得精确结果的操作指定此舍⼊模式,则抛出ArithmeticException。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。