喜悦无忧 2017-09-03 08:46 采纳率: 50%
浏览 1532
已采纳

java中关于浮点数值不适用于禁止出现舍入误差的金融计算中的问题

System.out.println(2.0-1.1);结果输出0.8999999999999999,而不是0.9,书上说,因为浮点数值采用二进制系统表示,所有没法精确到表示分数1/10,但是当我把2.0换成3.0时,输出的结果则是1.9。我有点想不通原因,请大家指教,谢谢!

  • 写回答

3条回答 默认 最新

  • 鼠晓 博客专家认证 2017-09-03 09:09
    关注

    借用《Effactive Java》这本书中的话,float和double类型的主要设计目标是为了科学计算和工程计算。他们执行二进制浮点运算,这是为了在广域数值范围上提供较为精确的快速近似计算而精心设计的。然而,它们没有提供完全精确的结果,所以不应该被用于要求精确结果的场合。但是,商业计算往往要求结果精确,这时候BigDecimal就派上大用场啦。

    参考链接:http://blog.csdn.net/jackiehff/article/details/8582449
    
    【为什么浮点计算不准确】参考这篇博客:http://blog.csdn.net/superherowupan/article/details/51315020
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog