提示:以下是本篇文章正文内容,下面案例可供参考
float类型与double类型的区别
float表示单精度浮点型,占用4个字节的内存空间,32个二进制位;
double表示双精度浮点型,占用8个字节的内存空间,64个二进制位;
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
}