【java解惑】使用double进行小数运算
2014-12-15 21:05
302 查看
如下代码:
原因分析: 1.1 这个数字不能被精确表示成为一个 double,因此它被表示成为最接近它的 double 值。该程序从 2 中减去的就是这个值。更根本的问题是:并不是所有的小数都可以用二进制浮点数来精确表示的。要想能够正确打印结果,一种可行的方案如上所示使用printf来格式化。另外一种方案是,使用BigDecimal来提供支持。使用BigDecimal需要注意的是使用字符串的构造函数而不是直接new BigDecimal(double)的构造方式。
另外需要格式化输出的字符串位数可以参考 /article/3801797.html
(注:本【java解惑】系列,均是博主阅读《java解惑》原书后,将原书上的讲解和例子部分改编,然后写成博文进行发布的。所有例子均亲自测试通过,并共享在github上。通过这些例子,激励自己,惠及他人。同时,本系列所有博文会同步发布在博主个人微信公众号(搜索“爱题猿”或者“ape_it”),方便大家阅读。如果文中有任何侵犯原作者权利的内容,请及时告知博主,以便及时删除;如果读者对文中的内容有异议或者问题,欢迎通过博客留言或者微信公众号留言等方式共同探讨。)源代码地址:https://github.com/rocwinger/java-disabuse
本文出自 “winger” 博客,谢绝转载!
public class Example002 { public static void main(String args[]) { System.out.println("println:( 2.00 - 1.10) = " + (2.00 - 1.10)); System.out.printf("printf:( 2.00 - 1.10) = %.2f%n", 2.00 - 1.10); System.out.println("BigDecimal:( 2.00 - 1.10) =" + new BigDecimal("2.00").subtract(new BigDecimal("1.10"))); } }输出结果:
println:( 2.00 - 1.10) = 0.8999999999999999 printf:( 2.00 - 1.10) = 0.90 BigDecimal:( 2.00 - 1.10) =0.90
原因分析: 1.1 这个数字不能被精确表示成为一个 double,因此它被表示成为最接近它的 double 值。该程序从 2 中减去的就是这个值。更根本的问题是:并不是所有的小数都可以用二进制浮点数来精确表示的。要想能够正确打印结果,一种可行的方案如上所示使用printf来格式化。另外一种方案是,使用BigDecimal来提供支持。使用BigDecimal需要注意的是使用字符串的构造函数而不是直接new BigDecimal(double)的构造方式。
另外需要格式化输出的字符串位数可以参考 /article/3801797.html
(注:本【java解惑】系列,均是博主阅读《java解惑》原书后,将原书上的讲解和例子部分改编,然后写成博文进行发布的。所有例子均亲自测试通过,并共享在github上。通过这些例子,激励自己,惠及他人。同时,本系列所有博文会同步发布在博主个人微信公众号(搜索“爱题猿”或者“ape_it”),方便大家阅读。如果文中有任何侵犯原作者权利的内容,请及时告知博主,以便及时删除;如果读者对文中的内容有异议或者问题,欢迎通过博客留言或者微信公众号留言等方式共同探讨。)源代码地址:https://github.com/rocwinger/java-disabuse
本文出自 “winger” 博客,谢绝转载!
相关文章推荐
- 【java解惑】使用double进行小数运算
- 我的Java开发学习之旅------>解惑Java进行三目运算时的自动类型转换
- java用double和float进行小数计算精度不准确
- java 解决double运算精度问题(使用BigDecimal )
- Java使用DateUtils对日期进行数学运算经典应用示例【附DateUtils相关包文件下载】
- Java中要使用 BigDecimal(定点数) 进行小数的相关操作,避免使用float等浮点数
- Java中使用BigDecimal进行精确运算
- 对于java中小数类型用Double或Float进行加减乘除时缺失精度问题
- Java使用BigDecimal保留double、float运算精度、保留指定位数有效数字、四舍五入
- Java中使用BigDecimal进行浮点数运算
- Java进阶(四十八)使用BigDecimal对浮点数进行精确运算
- java使用DateUtils对日期进行数学运算
- java 中使用BigDecimal进行数的四则运算
- Java使用BigDecimal保留double、float运算精度、保留指定位数有效数字、四舍五入
- JAVA中使用P和Q分量计算N和D进行RSA运算
- 【Java数据格式化】使用DecimalFormat 对Float和double进行格式化
- JAVA中使用P和Q分量计算N和D进行RSA运算
- java使用DateUtils对日期进行运算
- java用double和float进行小数计算精度不准确
- java 解决double运算精度问题(使用BigDecimal )