zoukankan      html  css  js  c++  java
  • BigDecimal.setScale 处理java小数点

    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则向下舍
     
     
    注释:
    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);
     
  • 相关阅读:
    关于相机权限
    JDBC插入中文出现乱码问题
    记一次Java代码的部署
    Java-final关键字
    Java枚举使用详解
    临时表
    Oracle 11g 建表 表名大小写问题
    ORA-04021等待锁定对象时超时
    Oracle 查询时间差几天
    NVL()
  • 原文地址:https://www.cnblogs.com/xiaoshen666/p/11007599.html
Copyright © 2011-2022 走看看