浮点型变量

  • Java 浮点类型常量有两种表示形式
           十进制数形式,例如:
                  3.14       314.0      0.314
        科学记数法形式,如
               314e2      314E2      314E-2
               double f = 314e2;  //314*10^2-->31400.0
              double f2 = 314e-2; //314*10^(-2)-->3.14
  • float类型又被称作单精度类型,尾数可以精确到7位有效数字,在很多情况下,float类型的精度很难满足需求。
  • double表示这种类型的数值精度是float类型的两倍,又被称作双精度,绝大部分应用程序都采用double类型。
  • 类型 占用存储空间 表数范围
    Float 4字节 -3.403E38~3.403E38
    Double 8字节 -1.798E308~1.798E308
  • 浮点类型float, double的数据不适合在不容许舍入误差的金融计算领域。
            如果需要进行不产生舍入误差的精确数字计算,需要使用BigDecimal
    注:
             主要理由:由于字长有限,浮点数能够精确表示的数是有限的,因而也是离散的。浮点数一般都存在舍入误差,很多数字无法精确表示(例如0.1),其结果只能是接近, 但不等于。
  • 由于其是近似存储,值越大,精度损失越大,越不精确!
  • Java.math下面的两个有用的类:BigInteger和BigDecimal,这两个类可以处理任意长度的数值。BigInteger实现了任意精度的整数运算。BigDecimal实现了任意精度的浮点运算。

猜你喜欢

转载自mylava.iteye.com/blog/2267718