java 四舍五入

方法一:

import java.text.DecimalFormat;
/**
 * 四舍五入
 * 
 * @param number为四舍五入的数字
 * @param keta是保留小数点之后的位数,从0开始
 * @description 0: 表示整数 (155.5->156.0) 1:(0.446->0.4) 2:(0.05 ->0.10) 3:(0.005-0.010)
 */
public static double rounds(double number, int keta) {

    String fmt = "";
    switch (keta) {
    case 0:
        fmt = "#0";
        break;
    case 1:
        fmt = "#0.0";
        break;
    case 2:
        fmt = "#0.00";
        break;
    case 3:
        fmt = "#0.000";
        break;

    default:
        fmt = "#0.0000";
        break;
    }

    DecimalFormat df = new DecimalFormat(fmt);

    return Double.valueOf(df.format(number));// new Double(df.format(number));

}

方法二:

/**
 * 提供精确的小数位四舍五入处理。
 * 
 * @param v
 *            需要四舍五入的数字
 * @param scale
 *            小数点后保留几位
 * @return 四舍五入后的结果
 */
public static double round(double v, int scale) {
    if (scale < 0) {
        throw new IllegalArgumentException("The scale must be a positive integer or zero");
    }
    BigDecimal b = new BigDecimal(Double.toString(v));
    BigDecimal one = new BigDecimal("1");
    return b.divide(one, scale, BigDecimal.ROUND_HALF_UP).doubleValue();
} 

  2020-12-17

  我们可以看到:开篇的double和这里的BigDecimal,都是为了格式化,那如果我现在需要用float,岂不是还要再创建一个方法?

  这就是所谓的:重复造轮子,如何将它们合并成一个方法?

/*
 * 四舍五入
 * @attention: 入参number是什么样的数据类型,返回值就是什么样的数据类型
 * 当要保留的位数>=待四舍五入的数字的小数位时,也就是decimals>=number的小数位,将会返回原来的数据,即number;
 * 只有在decimals<number的小数位时,才会执行四舍五入操作
 * @date: 2020年12月17日 0017 15:50
 * @param: number 待四舍五入的数字
 * @param: decimals 将要保留的小数位数 >=0
 * @return: T 四舍五入后的数字
 */
public static <T extends Number> T getNumberRound(T number, int decimals) {
    if (number == null) return null;

    log.debug("四舍五入前:" + number);
    // 格式
    String fmt;
    switch (decimals) {
        case 0:
            fmt = "#0";
            break;
        case 1:
            fmt = "#0.0";
            break;
        case 2:
            fmt = "#0.00";
            break;
        case 3:
            fmt = "#0.000";
            break;
        case 4:
            fmt = "#0.0000";
            break;

        default:
            fmt = "#0.0000";
            break;
    }

    // 格式化
    DecimalFormat df = new DecimalFormat(fmt);
    String numberStr = df.format(number);
    Number formatNumber;
    try {
        // 将格式化后的字符串转成对应的数值类型
        Constructor<? extends Number> constructor = number.getClass().getConstructor(String.class);
        formatNumber = constructor.newInstance(numberStr);
        // 上面两行代码相当于下面这行代码
        // formatNumber = new Double(numberStr);
        log.debug("四舍五入后:" + formatNumber);
    } catch (Exception e) {
        e.printStackTrace();
        return null;
    }
    return (T) formatNumber;
}  

  只要是继承了Number类型的数据类型都能调本方法。

  注意:如果是String类型也想使用本方法,先将其转换成number类型就成。

测试

  技巧分享:

  当我们不知道该用什么样的数据类型来接收返回值时,在idea中,可以这种方法让idea帮助我们自动识别。

  在后面输入:".var",按回车键

  再按一次回车,即可自动填充返回的数据类型及变量名称。

写在最后

  哪位大佬如若发现文章存在纰漏之处或需要补充更多内容,欢迎留言!!!

 相关推荐:

 

posted @ 2017-12-01 10:13  Marydon  阅读(394)  评论(0编辑  收藏  举报