本文主要讲解 BigDecimal 的比较运算,保留精度和取整和基础运算,BigDecimal 与其他数据类型转换。
比较运算
比较 num1 是否大于 num2
public static boolean gt(@NotNull BigDecimal num1, BigDecimal num2) { return num1.compareTo(num2) > 0; }
复制代码
比较 num1 是否小于 num2
public static boolean lt(@NotNull BigDecimal num1, BigDecimal num2) { return num1.compareTo(num2) < 0; }
复制代码
比较 num1 是否大于等于 num2
public static boolean ge(@NotNull BigDecimal num1, BigDecimal num2) { return num1.compareTo(num2) >= 0; }
复制代码
比较 num1 是否小于等于 num2
public static boolean le(@NotNull BigDecimal num1, BigDecimal num2) { return num1.compareTo(num2) <= 0; }
复制代码
比较 num1 是否等于 num2
public static boolean eq(@NotNull BigDecimal num1, BigDecimal num2) { return num1.compareTo(num2) == 0; }
复制代码
保留精度及取整
核心主要是 setScale(int newScale, int roundingMode) 方法。主要是两个参数:
newScale为小数位数;
roundingMode为取舍模式;
取整(保留 0 位小数)
/** * 取整返回int 类型 * @param num1 * @param roundingMode * @return */ public static int intValue(@NotNull BigDecimal num1,int roundingMode) { return num1.setScale(SCALA_ZERO, roundingMode).intValue(); }
复制代码
取整时setScale(int newScale, int roundingMode)第一个参数为 0,第二个为取舍模式。各个 roundingMode 详解如下:
ROUND_UP:正数时,舍弃小数后(整数部分)加 1,比如 100.39 结果为 100。负数时,舍弃小数后(整数部分)减去 1,-100.39 结果为 -101。
ROUND_DOWN:直接舍弃小数。
ROUND_CEILING:如果 BigDecimal 是正的,则做 ROUND_UP 操作;如果为负,则做 ROUND_DOWN 操作 (取附近较大的整数)。
ROUND_FLOOR: 如果 BigDecimal 是正的,则做 ROUND_DOWN 操作;如果为负,则做 ROUND_UP 操作(取附近较小的整数)。
ROUND_HALF_UP:四舍五入(取更近的整数)。
ROUND_HALF_DOWN:同 ROUND_HALF_UP 差别仅在于 0.5 时会向下取整。
ROUND_HALF_EVEN:取最近的偶数。
ROUND_UNNECESSARY:不需要取整,如果存在小数位,就抛 ArithmeticException 异常。
保留精度
四舍五入保留几位小数
/** * 四舍五入保留几位小数 * @param scala 保留几位 * @param num1 对应数值 * @return */ public static float halfUpValue(@NotNull BigDecimal num1,int scala) { return num1.setScale(scala, BigDecimal.ROUND_HALF_UP).floatValue(); }
复制代码
指定取舍规则,保留几位小数
/** * 指定取舍规则,保留几位小数 * @param scala 保留几位 * @param num1 对应数值 * @param roundingMode 取舍规则 * @return */ public static BigDecimal roundingModeValue(@NotNull BigDecimal num1,int scala,int roundingMode) { /** * 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 * setScale(1,BigDecimal.ROUND_HALF_DOWN)四舍五入,2.35变成2.3,如果是5则向下舍 */ return num1.setScale(scala, roundingMode); }
复制代码
基础运算
主要是以下方法:加:BigDecimal add(BigDecimal augend)减:BigDecimal subtract(BigDecimal subtrahend)乘:BigDecimal multiply(BigDecimal multiplicand)除:BigDecimal divide(BigDecimal divisor)取余:BigDecimal[] divideAndRemainder(BigDecimal divisor),返回一个 BigDecimal 数组,返回数组中包含两个元素,第一个元素为两数相除的商,第二个元素为余数。
BigDecimal 与其他数据类型转换
四舍五入保留几位小数返回字符串
/** * 四舍五入保留几位小数返回字符串 * @param tScala 保留几位 * @param num1 对应数值 * @param tRoundingMode 舍入类型 * @return */ public static String toPlainString(@NotNull BigDecimal num1, int tScala, int tRoundingMode) { return num1.setScale(tScala, tRoundingMode).toPlainString(); }
复制代码
四舍五入保留两位小数返回 double 类型
/** * 四舍五入保留两位小数返回double类型 * @param num1 * @return */ public static double doubleValue(@NotNull BigDecimal num1) { return num1.setScale(SCALA_TWO, BigDecimal.ROUND_HALF_UP).doubleValue(); }
复制代码
其他转换类似:floatValue()、 longValue() 、intValue()...。
本文内容到此结束了,
如有收获欢迎点赞👍收藏💖关注✔️,您的鼓励是我最大的动力。
如有错误❌疑问💬欢迎各位大佬指出。
主页:共饮一杯无的博客汇总👨💻
保持热爱,奔赴下一场山海。🏃🏃🏃
评论