public static void main(String[] args) {
long aa = System.currentTimeMillis();
// System.out.println(aa);
BigDecimal a = new BigDecimal(5);
BigDecimal b = new BigDecimal(8);
BigDecimal bigDecimal = a.divide(b).setScale(2, RoundingMode.HALF_UP);
System.out.println(bigDecimal);
long bb = System.currentTimeMillis();
System.out.println(bb-aa);
}
效果性能:(执行效率平均)
public static void main(String[] args) {
long aa = System.currentTimeMillis();
// System.out.println(aa);
BigDecimal a = new BigDecimal(5);
BigDecimal b = new BigDecimal(8);
// 转double
double v = a.divide(b, 2, RoundingMode.HALF_UP).doubleValue();
System.out.println(v);
long bb = System.currentTimeMillis();
System.out.println(bb-aa);
}
效果性能:(多次测试,大概率执行时间比没有转double输出长)可自测
使用建议:
在没有特定输出为double的情况下,建议使用BigDecimal自带的进行输出。具体使用还需自测,有好的意见请评论区留言,一起学习探讨!
注意:
setScale(2)会报错如下:
需要指定:
使用BigDecimal先除再保留小数,报Non-terminating decimal expansion; no exact representable decimal result.异常
解决方法:只需要在 divide() 方法中传入 MathContext 对象或 RoundingMode 对象,指定精度和舍入模式就可以解决该问题。
BigDecimal a = new BigDecimal(1);
BigDecimal b = new BigDecimal(3);
a.divide(b,2, BigDecimal.ROUND_CEILING);
文末分享:
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)向最接近的数字舍入,如果与两个相邻数字的距离相等,则向相邻的偶数舍入。
————————————————
最后,请留意:
如果对你有帮助,给博主一个免费的点赞以示鼓励
欢迎各位点赞评论收藏⭐️