为什么float赋值要加f,double不用呢? 不都是小数吗 只不过精度不同
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。
不同之处有四处:
单精度浮点数(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型……