JAVA解惑--找零时刻
来源:互联网 发布:微盘交易平台源码 编辑:程序博客网 时间:2024/05/01 17:28
问题:下述程序能否得到你想要的结果
System.out.println(2.00-1.10); //结果为0.8999999999999999
从结果可知,并没有得到想要的结果0.90.
原因是1.1这个数字不能被精确表示为一个double,而是被表示为最接近它的double值,从而参与运算的是最接近的double值,而非1.1。
一般的,并不是所有的小数都可以用二进制浮点数精确表示。
浮点运算在一个范围很广的值域上提供了很好的近似,但通常不能产生精确的结果。
解决方案:
使用执行精确运算的BigDecimal
但是要用
BigDecimal(String val) 将 BigDecimal 的字符串表示形式转换为 BigDecimal。
而不是
BigDecimal(double val) 将 double 转换为 BigDecimal,后者是 double 的二进制浮点值准确的十进制表示形式。
看如下程序:
System.out.println(new BigDecimal("2.0").subtract(new BigDecimal("1.10")));System.out.println(new BigDecimal(2.0).subtract(new BigDecimal(1.10)));
结果分别为:
0.900.899999999999999911182158029987476766109466552734375
从而可以看出要使用第一个构造器。
所以,涉及到精度要求很高的时候,要使用BigDecimal等解决方案。
- JAVA解惑--找零时刻
- java 解惑-----找零时刻
- Java解惑之找零时刻
- Java解惑1-2找零时刻
- java解惑--谜题2:找零时刻
- java解惑之找零时刻(浮点运算)
- 《Java解惑》系列——01表达式之谜——谜题02:找零时刻
- Java谜题2:找零时刻
- 找零时刻
- 找零时刻
- 找零时刻
- 2.找零时刻
- 找零时刻谜题
- NO.2 找零时刻
- 谜题2:找零时刻
- 谜题2 找零时刻
- 找零时刻---浮点数计算
- 谜题2:Time for a change 找零时刻
- 装修
- 每个类一张表
- 使用mysql的命令行进行大文件的导入
- 在win32应用中使用printf代码示例
- ctags用法
- JAVA解惑--找零时刻
- 利用ffmpeg0.6.1把.h264纯码流打包成.mp4 .avi等格式
- 使用python爬虫抓站的一些技巧总结:进阶篇
- AJAX
- android u-boot.bin具体分析
- 详解extern "C"
- asp.net常用函数表
- 编译Directshow中的NullInPlace所遇见的错误 2011.07.27
- 写文件实例