• BigDecimal的setScale()方法无效(坑)


    最近在使用BigDecimal进行四舍五入时,发现setScale()方法设置的精度值并没有起作用,一度让我怀疑起是否jdk有bug,代码如下:

    错误代码 
    double d = 7.199999999999999; 
    BigDecimal decimal = new BigDecimal(String.valueOf(d)); 
    decimal.setScale(2, BigDecimal.ROUND_HALF_UP); 
    System.out.println(decimal.scale()); 
    System.out.println(decimal.doubleValue()); 
    System.out.println(decimal.toString()); 
    以上代码目的:将7.199999999999999保留两位小数后输出。 输出结果:

    15 
    7.199999999999999 
    7.199999999999999 
    可以看到,decimal.setScale(2, BigDecimal.ROUND_HALF_UP);并没有起作用。

    正确代码 
    double d = 7.199999999999999; 
    BigDecimal decimal = new BigDecimal(String.valueOf(d)); 
    //重新生成了新的对象 
    BigDecimal decimal2 = decimal.setScale(2, BigDecimal.ROUND_HALF_UP); 
    System.out.println(“—————decimal1————-“); 
    System.out.println(decimal.scale()); 
    System.out.println(decimal.doubleValue()); 
    System.out.println(decimal.toString()); 
    System.out.println(“—————decimal2————-“); 
    System.out.println(decimal2.scale()); 
    System.out.println(decimal2.doubleValue()); 
    System.out.println(decimal2.toString()); 
    与错误代码不同的是,用decimal2接收decimal.setScale(2, BigDecimal.ROUND_HALF_UP)的返回结果,并操作decimal2,输出如下:

    —————decimal1————- 
    15 
    7.199999999999999 
    7.199999999999999 
    —————decimal2————- 

    7.2 
    7.20 
    总结 
    decimal.setScale(2, BigDecimal.ROUND_HALF_UP)会生成新的对象,设置的精度值只对新对象有效,对原对象无效,需注意。 一般来说,可以使用链式方式构造新对象并设置精度:

    BigDecimal decimal = new BigDecimal(String.valueOf(d)).setScale(2, BigDecimal.ROUND_HALF_UP);

  • 相关阅读:
    showModalDialog()、showModelessDialog()方法使用详解
    Oracle 8i在GNU/Linux上的安装笔记
    TURBOLinux 7.0下安装Oracle 8.1.7.0.1 release 3
    [Oracle]初识Oracle8i(8.0.5)
    (三)
    退出win不保存设置
    Windows 2000/NT/XP管理员密码丢失解决方法
    DCOM错误:DefaultLaunchPermssion 访问被拒绝
    找到一些工具
    O/R MAP 和 ObjectSpaces 资料
  • 原文地址:https://www.cnblogs.com/xifenglou/p/9993289.html
Copyright © 2020-2023  润新知