zoukankan      html  css  js  c++  java
  • BigDecimal.setScale用法总结

    1. BigDecimal num1 = new BigDecimal(2.225667);//这种写法不允许,会造成精度损失

    2. BigDecimal num2 = new BigDecimal(2);//这种写法是可以的

    3. BigDecimal num = new BigDecimal("2.225667");//一般都会这样写最好

    4. int count = num.scale();

            System.out.println(count);//6 返回的是小数点后位数

    好了,下面开始正式介绍知识点啦~~~~~~


    1. ROUND_DOWN

    1.  
      BigDecimal b = new BigDecimal("2.225667").setScale(2, BigDecimal.ROUND_DOWN);
    2.  
      System.out.println(b);//2.22 直接去掉多余的位数

    2. ROUND_UP

    1.  
      BigDecimal c = new BigDecimal("2.224667").setScale(2, BigDecimal.ROUND_UP);
    2.  
      System.out.println(c);//2.23 跟上面相反,进位处理

    3. ROUND_CEILING

    天花板(向上),正数进位向上,负数舍位向上

    1.  
      BigDecimal f = new BigDecimal("2.224667").setScale(2, BigDecimal.ROUND_CEILING);
    2.  
      System.out.println(f);//2.23 如果是正数,相当于BigDecimal.ROUND_UP
    3.  
       
    4.  
      BigDecimal g = new BigDecimal("-2.225667").setScale(2, BigDecimal.ROUND_CEILING);
    5.  
      System.out.println(g);//-2.22 如果是负数,相当于BigDecimal.ROUND_DOWN

    4. ROUND_FLOOR

    地板(向下),正数舍位向下,负数进位向下

    1.  
      BigDecimal h = new BigDecimal("2.225667").setScale(2, BigDecimal.ROUND_FLOOR);
    2.  
      System.out.println(h);//2.22 如果是正数,相当于BigDecimal.ROUND_DOWN
    3.  
       
    4.  
      BigDecimal i = new BigDecimal("-2.224667").setScale(2, BigDecimal.ROUND_FLOOR);
    5.  
      System.out.println(i);//-2.23 如果是负数,相当于BigDecimal.ROUND_HALF_UP

    5. ROUND_HALF_UP

    1.  
      BigDecimal d = new BigDecimal("2.225").setScale(2, BigDecimal.ROUND_HALF_UP);
    2.  
      System.out.println("ROUND_HALF_UP"+d); //2.23 四舍五入(若舍弃部分>=.5,就进位)

    6. ROUND_HALF_DOWN

    1.  
      BigDecimal e = new BigDecimal("2.225").setScale(2, BigDecimal.ROUND_HALF_DOWN);
    2.  
      System.out.println("ROUND_HALF_DOWN"+e);//2.22 四舍五入(若舍弃部分>.5,就进位)

    7. ROUND_HALF_EVEN

    1.  
      BigDecimal j = new BigDecimal("2.225").setScale(2, BigDecimal.ROUND_HALF_EVEN);
    2.  
      System.out.println(j);//2.22 如果舍弃部分左边的数字为偶数,则作 ROUND_HALF_DOWN
    3.  
       
    4.  
      BigDecimal k = new BigDecimal("2.215").setScale(2, BigDecimal.ROUND_HALF_EVEN);
    5.  
      System.out.println(k);//2.22 如果舍弃部分左边的数字为奇数,则作 ROUND_HALF_UP
    6.  
       
    7.  
       
    8.  
      System.out.println("************************************");
    9.  
       
    10.  
      System.out.println("4.05: "+new BigDecimal("4.05").setScale(1, BigDecimal.ROUND_HALF_EVEN));//4.05: 4.0 down
    11.  
      System.out.println("4.15: "+new BigDecimal("4.15").setScale(1, BigDecimal.ROUND_HALF_EVEN));//4.15: 4.2 up
    12.  
      System.out.println("4.25: "+new BigDecimal("4.25").setScale(1, BigDecimal.ROUND_HALF_EVEN));//4.25: 4.2 down
    13.  
      System.out.println("4.35: "+new BigDecimal("4.35").setScale(1, BigDecimal.ROUND_HALF_EVEN));//4.35: 4.4 up
    14.  
      System.out.println("4.45: "+new BigDecimal("4.45").setScale(1, BigDecimal.ROUND_HALF_EVEN));//4.45: 4.4 down
    15.  
      System.out.println("4.55: "+new BigDecimal("4.55").setScale(1, BigDecimal.ROUND_HALF_EVEN));//4.55: 4.6 up
    16.  
      System.out.println("4.65: "+new BigDecimal("4.65").setScale(1, BigDecimal.ROUND_HALF_EVEN));//4.65: 4.6 down
    17.  
       
    18.  
      System.out.println("3.05: "+new BigDecimal("3.05").setScale(1, BigDecimal.ROUND_HALF_EVEN));//3.05: 3.0 down
    19.  
      System.out.println("3.15: "+new BigDecimal("3.15").setScale(1, BigDecimal.ROUND_HALF_EVEN));//3.15: 3.2 up
    20.  
      System.out.println("3.25: "+new BigDecimal("3.25").setScale(1, BigDecimal.ROUND_HALF_EVEN));//3.25: 3.2 down
    21.  
      System.out.println("3.35: "+new BigDecimal("3.35").setScale(1, BigDecimal.ROUND_HALF_EVEN));//3.35: 3.4 up
    22.  
      System.out.println("3.45: "+new BigDecimal("3.45").setScale(1, BigDecimal.ROUND_HALF_EVEN));//3.45: 3.4 down
    23.  
      System.out.println("3.55: "+new BigDecimal("3.55").setScale(1, BigDecimal.ROUND_HALF_EVEN));//3.55: 3.6 up
    24.  
      System.out.println("3.65: "+new BigDecimal("3.65").setScale(1, BigDecimal.ROUND_HALF_EVEN));//3.65: 3.6 down

    8.ROUND_UNNECESSARY
    1.  
      BigDecimal l = new BigDecimal("2.215").setScale(3, BigDecimal.ROUND_UNNECESSARY);
    2.  
      System.out.println(l);
    3.  
      //断言请求的操作具有精确的结果,因此不需要舍入。
    4.  
      //如果对获得精确结果的操作指定此舍入模式,则抛出ArithmeticException。
     
  • 相关阅读:
    nginx + keepalived 教程
    mysql 之 获取指定月份天数和指定月份上月天数
    hive 之将sql执行结果输出到文件中
    sql 之 处理一行全为0的记录
    Shell 基础知识
    kettle 调度时出现时区问题,导致数据调出加了8小时
    sql 之按指定分割符取分割符前/后字符串
    Spring Security(二)
    Spring Security(一)
    集成Swagger文档
  • 原文地址:https://www.cnblogs.com/cyl048/p/9365580.html
Copyright © 2011-2022 走看看