由于每次都要处理小数,很麻烦,所以封装一个工具类来去处理,这个工具类专门用来处理小数位的,就比如我是double、float、Double、Float、BigDecimal、String这些。工具类提供三个参数,一个是泛型的value用来传入任何类型的(double、float、Double、Float、BigDecimal、String)值,一个是保留多少位scale用来截取多少位,一个是是否需要四舍五入判断指标isHalf用来判断是否需要四舍五入,如我value是double类型1.336,scale是2,isHalf是true,那么就会给我返回double类型的1.34
package com.ckm.ball.utils;
import java.math.BigDecimal;
import java.math.RoundingMode;
public class DecimalValueHandle {
/**
* 格式化小数
*
* @param <T> 数字类型可以是 double, Double, float, Float, String, BigDecimal
* @param value 要格式化的数字
* @param scale 保留的小数位数
* @param isHalf 是否四舍五入
* @return 格式化后的数字
*/
public static <T> T formatDecimal(T value, int scale, boolean isHalf) {
//值不能为空
if (value == null) {
throw new IllegalArgumentException("输入的数字不能为空");
}
//只能>=0
if (scale < 0) {
throw new IllegalArgumentException("保留的小数位数不能小于0");
}
BigDecimal decimal;
// 根据类型进行处理,instanceof用于判断值的类型
if (value instanceof Double || value instanceof Float || value instanceof BigDecimal) {
decimal = new BigDecimal(value.toString());
} else if (value instanceof String) {
try {
decimal = new BigDecimal((String) value);
} catch (NumberFormatException e) {
throw new IllegalArgumentException("字符串格式不正确");
}
} else {
throw new IllegalArgumentException("不支持的数据类型");
}
// 设置小数位数和舍入模式
if (scale == 0) {
// 如果保留位数为0,直接取整数部分
decimal = decimal.setScale(0, RoundingMode.DOWN);
} else {
// 如果保留位数不为0,则判断是否需要四舍五入,再保留位数
decimal = decimal.setScale(scale, isHalf ? RoundingMode.HALF_UP : RoundingMode.DOWN);
}
// 返回处理后的结果,根据输入类型返回
if (value instanceof Double) {
return (T) Double.valueOf(decimal.doubleValue());
} else if (value instanceof Float) {
return (T) Float.valueOf(decimal.floatValue());
} else if (value instanceof BigDecimal) {
return (T) decimal;
} else if (value instanceof String) {
return (T) decimal.toString();
} else {
throw new IllegalArgumentException("不支持的数据类型");
}
}
public static void main(String[] args) {
// 示例使用
double exampleDouble = 1.336;
Double exampleDoubleObject = 1.336;
float exampleFloat = 1.336f;
Float exampleFloatObject = 1.336f;
BigDecimal exampleBigDecimal = new BigDecimal("1.336");
String exampleString = "1.336";
// 保留两位小数,四舍五入
System.out.println(formatDecimal(exampleDouble, 2, true)); // 输出 1.34
System.out.println(formatDecimal(exampleDoubleObject, 2, true)); // 输出 1.34
System.out.println(formatDecimal(exampleFloat, 2, true)); // 输出 1.34
System.out.println(formatDecimal(exampleFloatObject, 2, true)); // 输出 1.34
System.out.println(formatDecimal(exampleBigDecimal, 2, true)); // 输出 1.34
System.out.println(formatDecimal(exampleString, 2, true)); // 输出 1.34
// 保留两位小数,不四舍五入
System.out.println(formatDecimal(exampleDouble, 2, false)); // 输出 1.33
System.out.println(formatDecimal(exampleDoubleObject, 2, false)); // 输出 1.33
System.out.println(formatDecimal(exampleFloat, 2, false)); // 输出 1.33
System.out.println(formatDecimal(exampleFloatObject, 2, false)); // 输出 1.33
System.out.println(formatDecimal(exampleBigDecimal, 2, false)); // 输出 1.33
System.out.println(formatDecimal(exampleString, 2, false)); // 输出 1.33
// 保留0位小数,取整数部分
System.out.println(formatDecimal(exampleDouble, 0, true)); // 输出 1
System.out.println(formatDecimal(exampleDoubleObject, 0, true)); // 输出 1
System.out.println(formatDecimal(exampleFloat, 0, true)); // 输出 1
System.out.println(formatDecimal(exampleFloatObject, 0, true)); // 输出 1
System.out.println(formatDecimal(exampleBigDecimal, 0, true)); // 输出 1
System.out.println(formatDecimal(exampleString, 0, true)); // 输出 1
}
}