ROUND_CEILING 向正无穷方向舍入
ROUND_DOWN 向零方向舍入
ROUND_FLOOR 向负无穷方向舍入
ROUND_HALF_DOWN 向(距离)最近的一边舍入,除非两边(的距离)是相等,如果是这样,向下舍入, 例如1.55 保留一位小数结果为1.5
ROUND_HALF_UP 向(距离)最近的一边舍入,除非两边(的距离)是相等,如果是这样,向上舍入, 1.55保留一位小数结果为1.6
ROUND_HALF_EVEN 向(距离)最近的一边舍入,除非两边(的距离)是相等,如果是这样,如果保留位数是奇数,使用ROUND_HALF_UP ,如果是偶数,使用ROUND_HALF_DOWN
ROUND_UNNECESSARY 计算结果是精确的,不需要舍入模式
ROUND_UP 向远离0的方向舍入
案例
BigDecimal decimal = new BigDecimal("3.16974432");//1.98764432System.out.println(decimal);BigDecimal setScale = decimal.setScale(4,BigDecimal.ROUND_HALF_DOWN);System.out.println(setScale);BigDecimal setScale1 = decimal.setScale(4,BigDecimal.ROUND_HALF_UP);System.out.println(setScale1);
BigDecimal 损失精度、科学计数、去除数字末位0、DecimalFormat等问题(详解)_小情歌i的博客-CSDN博客_bigdecimal科学计数法
1.代码
BigDecimal decimal = new BigDecimal("3.16974497273E9");System.out.println(decimal);BigDecimal setScale = decimal.setScale(4,BigDecimal.ROUND_HALF_DOWN);System.out.println(setScale);BigDecimal setScale1 = decimal.setScale(4,BigDecimal.ROUND_HALF_UP);System.out.println(setScale1);
2.结果:
1.数据库字段设置decimal
2.实体
3.运算
1.四舍五入
public BigDecimal getScienceDecimalVale(BigDecimal resultValue){BigDecimal setScale = resultValue.setScale(2,BigDecimal.ROUND_HALF_UP);logger.info("解决科学计算法: 原来值:"+resultValue+" 保留2位小数:"+setScale);// String finishResult= resultValue.setScale(2, BigDecimal.ROUND_HALF_UP).toString();//System.out.println("解决科学计算法:"+finishResult);return setScale;}
2.相减
3.相乘
上一篇:AOP简单示例