Java中float与double之间的区别?

文章目录

  • float类型与double类型的区别
  • 测试用例
  • Ending~!


提示:以下是本篇文章正文内容,下面案例可供参考

float类型与double类型的区别

float表示单精度浮点型,占用4个字节的内存空间,32个二进制位;
double表示双精度浮点型,占用8个字节的内存空间,64个二进制位;

Java中float与double之间的区别?_第1张图片

float指数位二进制为8位,double指数位二进制位为11位,所以:
float类型的指数范围:-127~128;
double类型的指数范围:-1023~1024;

float尾数位二进制位为23位,double尾数位二进制位为16位,所以:
float类型的尾数范围:2^23 = 8388608
double类型的尾数范围:2^52 = 4503599627370496

浮点数值的基本表达式为:浮点数值=尾数 * 底数 ^ 指数,所以:
float的范围为-2^128 ~ +2^128,表示为-3.40E+38 ~ +3.40E+38;
double的范围为-2^1024 ~+2^1024,表示为-1.79E+308 ~ +1.79E+308;

提示:e(E)是exponent的缩写,意为指数.这里特指e右边的数是以10为底的指数.例如-3.4e+38表示-3.4×10^(38),实际上就是一般意义上的科学记数法。

测试用例

为了区别float和double,float型定义的数据末尾必须有"f"或"F",double末尾可以有"d"也可以不写;

    public static void main(String[] args) {
        float f2 = 3.1415926999999F;
        System.out.println(f2); 
        //输出3.1415927,因为存在精度损失;
        double f = 3.1415926999999F;
        System.out.println(f);  
        //输出3.1415927_410125732,因为3.1415926999999F精度损失变为3.1415927,float再转为double(向上转型,宽化),后面的410125732为随机生成;
        double f1 = 3.1415926999999;
        System.out.println(f1); 
        //输出3.1415926999999
    }

参考

  • Ending~!

你可能感兴趣的:(Java,java,开发语言)