为什么float赋值要加f,double不用呢? 不都是小数吗 只不过精度不同

来源:2-6 Java中的数据类型

jackrabbit

2016-03-13 11:34

为什么float赋值要加f,double不用呢?  不都是小数吗 只不过精度不同

写回答 关注

2回答

  • nosilence
    2016-03-13 11:44:08
    已采纳

    JAVA是一种强类型语言,你在做赋值运算的时候其实等号两边的类型都是确定的,能赋值成功,要么两边类型一致,要么两边类型具备某种关系(继承或者实现),要么编译器通过上下文可以判定。比如:

    byte x = 1;

    1是个整数字面量,是int类型,这个值在byte类型的范围之内,这个时候编译器会帮你做类型转换,只留下int类型8位,前面的0都去掉。
    而在JAVA中浮点类型的字面量类型默认是double,但是由于float类型和double类型在内存中的二进制表现形式不同:一个8位;一个4位。编译器在编译的时候扫描到了一个25.6,在不带F的情况下,它会判断这是double类型,应该创建一个8个字节的空间来存放;带上F,编译器就会创建一个4字节的空间来存放。float不能像整形那样有时会默认转换,必须要确定类型,带上F。

    jackra...

    理解了,谢谢。

    2016-03-13 11:50:55

    共 1 条回复 >

  • 杨东瀛
    2016-03-13 11:39:52

    不同之处有四处:

    单精度浮点数(float)与双精度浮点数(double)的区别如下:

    (1)在内存中占有的字节数不同

    单精度浮点数在机内占4个字节

    双精度浮点数在机内占8个字节

    (2)有效数字位数不同

    单精度浮点数有效数字8位

    双精度浮点数有效数字16位

    (3)所能表示数的范围不同

    单精度浮点的表示范围:-3.40E+38 ~ +3.40E+38

    双精度浮点的表示范围:-1.79E+308 ~ +1.79E+308

    (4)在程序中处理速度不同
    一般来说,CPU处理单精度浮点数的速度比处理双精度浮点数快

    至于要加F是因为就是这么规定的……如果不加F的话他会认为你是用的Double型……

    qq_緐華丗... 回复jackra...

    同 问

    2016-03-22 16:58:21

    共 2 条回复 >

Java入门第一季(IDEA工具)升级版

0基础萌新入门第一课,从Java环境搭建、工具使用、基础语法开始

1165172 学习 · 17581 问题

查看课程

相似问题