• 问题记录——BigDecimal保留两位小数及格式化成百分比


    1、函数总结

    • BigDecimal.setScale()方法用于格式化小数点
    • setScale(1)表示保留一位小数,默认用四舍五入方式
    • 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
    • setScaler(1,BigDecimal.ROUND_HALF_DOWN)四舍五入,2.35变成2.3,如果是5则向下舍
    • setScaler(1,BigDecimal.ROUND_CEILING)接近正无穷大的舍入
    • setScaler(1,BigDecimal.ROUND_FLOOR)接近负无穷大的舍入,数字>0和ROUND_UP作用一样,数字<0和ROUND_DOWN作用一样
    • setScaler(1,BigDecimal.ROUND_HALF_EVEN)向最接近的数字舍入,如果与两个相邻数字的距离相等,则向相邻的偶数舍入。

    2、代码

    public class Demo {
       public static void main(String[] args) {
      BigDecimal a =null;
      Integer faultRate = 6;
      a = BigDecimal.valueOf(faultRate.doubleValue()/3);
      BigDecimal  b =a.setScale(2, RoundingMode.HALF_UP);//保留两位小数
      System.out.println("结果是"+b);
      //下面将结果转化成百分比
      NumberFormat percent = NumberFormat.getPercentInstance();
           percent.setMaximumFractionDigits(2);
    
    
           System.out.println(percent.format(b.doubleValue()));
      
    }
    }

    注释:
    1:scale指的是你小数点后的位数。比如123.456则score就是3.
    score()就是BigDecimal类中的方法啊。
    比如:BigDecimal b = new BigDecimal("123.456");
    b.scale(),返回的就是3.
    2:roundingMode是小数的保留模式。它们都是BigDecimal中的常量字段,有很多种。
    比如:BigDecimal.ROUND_HALF_UP表示的就是4舍5入。
    3:pubilc BigDecimal divide(BigDecimal divisor, int scale, int roundingMode)
    的意思是说:我用一个BigDecimal对象除以divisor后的结果,并且要求这个结果保留有scale个小数位,roundingMode表示的就是保留模式是什么,是四舍五入啊还是其它的,你可以自己选!
    4:对于一般add、subtract、multiply方法的小数位格式化如下:

    BigDecimal mData = new BigDecimal("9.655").setScale(2, BigDecimal.ROUND_HALF_UP);
    System.out.println("mData=" + mData);
    ----结果:----- mData=9.66

    原文链接:https://blog.csdn.net/m0_37044606/article/details/76461569

    未解决问题如下:

          BigDecimal a =null;
            double fault =  1.585;
    
            a = BigDecimal.valueOf(fault);
            BigDecimal  b =a.setScale(2, RoundingMode.HALF_UP);
            System.out.println("结果是"+b);
    
            BigDecimal c = new BigDecimal(fault).setScale(2, BigDecimal.ROUND_HALF_UP);
            System.out.println("结果是"+c);

    两次输出结果如下:(两种方法取值向上向下的问题模糊)

     替换数值后

         BigDecimal a =null;
            double fault =  1.685;
    
            a = BigDecimal.valueOf(fault);
            BigDecimal  b =a.setScale(2, RoundingMode.HALF_UP);
            System.out.println("结果是"+b);
    
            BigDecimal c = new BigDecimal(fault).setScale(2, BigDecimal.ROUND_HALF_UP);
            System.out.println("结果是"+c);

    结果:

    各位大佬,有谁知道的嘛 

  • 相关阅读:
    类的加载过程 以及实例的加载顺序
    设计优化之单例模式
    Java程序性能优化之性能概述
    1-12接口
    1-11多态
    1-9方法的重写(override)
    1-6static关键字
    1-10super和this关键字
    1-8继承extends
    1-7代码块的分类
  • 原文地址:https://www.cnblogs.com/lx06/p/15759227.html
Copyright © 2020-2023  润新知