zoukankan      html  css  js  c++  java
  • java 小数精确计算

     1 小数精确计算 
     2 
     3 System.out.println(2.00 -1.10);//0.8999999999999999
     4 
     5 
     6 
     7 上面的计算出的结果不是 0.9,而是一连串的小数。问题在于1.1这个数字不能被精确表示为一个double,因此它被表 
     8 
     9 示为最接近它的double值,该程序从2中减去的就是这个值,但这个计算的结果并不是最接近0.9的double值。 
    10 
    11 
    12 一般地说,问题在于并不是所有的小数都可以用二进制浮点数精确表示。 
    13 
    14 
    15 二进制浮点对于货币计算是非常不适合的,因为它不可能将1.0表示成10的其他任何负次幂。 
    16 
    17 
    18 解决问题的第一种方式是使用货币的最小单位(分)来表示: 
    19 
    20 System.out.println(200-110);//90
    21 
    22 
    23 
    24 第二种方式是使用BigDecimal,但一定要用BigDecimal(String)构造器,而千万不要用 BigDecimal(double)来构造(也不能将float或double型转换成String再来使用BigDecimal(String)来构造,因为在将float或double转换成String时精度已丢失)。 
    25 例如new BigDecimal(0.1), 
    26 它将返回一个BigDecimal, 
    27 也即0.100000000000000005551115123125782702118158340454101562528 正确使用BigDecimal,程序就可以打印出我们所期 
    29 
    30 望的结果0.931 
    32 System.out.println(new BigDecimal("2.0").subtract(new BigDecimal("1.10")));// 0.9
    33 
    34 
    35 
    36 另外,如果要比较两个浮点数的大小,要使用BigDecimal的compareTo方法。
  • 相关阅读:
    Timer类的常见使用方法
    转:HTTP协议简介
    DS-5新加交叉编译工具
    C++的引用
    C++构造函数的几种使用方法
    Eclipse 快捷键
    eclipse Outline里图标的含义
    Linux 内存映射函数 mmap()函数详解
    Sockit 硬件接口编程——点亮一个LED
    更新Preloader与uboot
  • 原文地址:https://www.cnblogs.com/-lpf/p/5996676.html
Copyright © 2011-2022 走看看