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

  • 相关阅读:
    DBImport v3.44 中文版发布:数据库数据互导及文档生成工具(IT人员必备)
    IT人生知识分享:博弈论的理性思维
    IT人生知识分享:概率与运气
    开源:秋式广告杀手源码
    浅说秋色园域名被国家互联网应急中心封与解的过程
    自定义可视化调试工具(Microsoft.VisualStudio.DebuggerVisualizers)
    Excel导入导出的业务进化场景及组件化的设计方案(上)
    回忆录:30岁那年,你成长了吗?(上篇)
    Excel导入导出组件的设计
    DBImport v3.3 中文版发布:数据库数据互导及文档生成工具(IT人员必备)
  • 原文地址:https://www.cnblogs.com/congcongdi/p/12208444.html
Copyright © 2011-2022 走看看