Java中float与double之间的区别?


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

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
    }

参考

  • Ending~!

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值