zoukankan      html  css  js  c++  java
  • java里的四舍五入(保留两位小数,返回double类型)

    1、最简单的操作,验证之后是准确的四舍五入

    double payPercent=123.345;
    System.out.println((double)Math.round(payPercent*100)/100);

    输出结果:123.35

    2、使用BigDecimal

    1、 ROUND_UP:远离零方向舍入。向绝对值最大的方向舍入,只要舍弃位非0即进位。(备注:就是只要第三位不是0,都往前进1。如1.121,输出会是1.13)

    double payPercent=123.343;
    BigDecimal bg = new BigDecimal(payPercent).setScale(2, RoundingMode.UP);
    System.out.println(bg.doubleValue());

      输出结果123.35

    2、 ROUND_DOWN:趋向零方向舍入。向绝对值最小的方向输入,所有的位都要舍弃,不存在进位情况。

    double payPercent=123.349;
    BigDecimal bg = new BigDecimal(payPercent).setScale(2, RoundingMode.DOWN);
    System.out.println(bg.doubleValue());

      输出结果123.34

    3、 ROUND_CEILING:向正无穷方向舍入。向正最大方向靠拢。若是正数,舍入行为类似于ROUND_UP,若为负数,舍入行为类似于ROUND_DOWN。Math.round()方法就是使用的此模式。(没测试)

    4、 ROUND_FLOOR:向负无穷方向舍入。向负无穷方向靠拢。若是正数,舍入行为类似于ROUND_DOWN;若为负数,舍入行为类似于ROUND_UP。(没测试)

    5、 HALF_UP:最近数字舍入(5进)。这是我们最经典的四舍五入。-----备注:都说这里是四舍五入,程序里的例子也是如此,但是经过测试,实际上是五舍六入

    double payPercent=123.345;
    BigDecimal bg = new BigDecimal(payPercent).setScale(2, RoundingMode.HALF_UP);
    System.out.println(bg.doubleValue());

      输出结果是123.34

     后来经过查找资料,有人说

    double payPercent=123.345;
    BigDecimal bg = new BigDecimal(String.valueOf(payPercent)).setScale(2, RoundingMode.HALF_UP);
    System.out.println(bg.doubleValue());

      输出结果是123.35-----正确的四舍五入处理

     6、 HALF_DOWN:最近数字舍入(5舍)。在这里5是要舍弃的。---即使按照上一步修改设置,也是会在5的时候舍去

    7、 HAIL_EVEN:银行家舍入法。--(测试了下,好像5也是舍去的,具体不太清楚)

    3、其他操作

    double payPercent=123.345;
    NumberFormat nf = NumberFormat.getNumberInstance();
    // 保留两位小数
    nf.setMaximumFractionDigits(2);
    nf.setRoundingMode(RoundingMode.HALF_UP);
    System.out.println(nf.format(payPercent));
    
    DecimalFormat df = new DecimalFormat("#.00");
    System.out.println(df.format(payPercent));            

      输出结果:123.34

  • 相关阅读:
    wcf 配置
    一般处理程序问题重命名后问题
    jQuery取得select选择的文本与值
    C# 读取excel
    ajax 跨域问题
    java转义字符
    oracle日期时间的加减法
    在MyEclipse中,jsp文件输入中文,文件不能保存
    转自JavaEye Oracle函数大全
    转Oracle数据类型及存储方式【F】
  • 原文地址:https://www.cnblogs.com/congcongdi/p/12208444.html
Copyright © 2011-2022 走看看