黑马程序员技术交流社区
标题:
long为什么可以隐式转换到float?
[打印本页]
作者:
Liveei
时间:
2015-8-21 22:43
标题:
long为什么可以隐式转换到float?
class Test
{
public static void main(String[] args)
{
long l= 8888888;
float f= 9.8f;
f=l;
System.out.println(f);
}
}
long 是8字节的,然后flout是4字节,为毛long可以隐式转换到float?
作者:
Marx_D
时间:
2015-8-21 23:10
看取值范围,而且浮点型和整形数据的编码方式不一样。可以找相关的书籍看看
作者:
何时指点江山
时间:
2015-8-21 23:14
这两种在底层用的是不同的存储方式,不能用简单的字节多少来判断了
作者:
jungle_2329
时间:
2015-8-21 23:29
这个是因为浮点型和整型数据编码形式不一样
作者:
binarycoc
时间:
2015-8-21 23:44
深究起来有说头 float其实很大
作者:
sunsteam
时间:
2015-8-22 00:03
float直接赋值给int反而不行 我觉得只能这么理解 整型都是精确的数 把一个精确的数赋值给一个代表大致精度的浮点型 是可以接受的 浮点型本身的范围很大 但是把一个表示大致精度的浮点型赋值给精确的整型 那么必定是不够精确的咯
关于浮点型的准确度 可以用下面的语句试一下 看到结果你就知道了
float f1 = 2000000000;
float f2 = 2000000050;
System.out.println(f1==f2);
作者:
liuch111
时间:
2015-8-22 10:44
都是大神
作者:
Liveei
时间:
2015-9-12 16:23
基础班快结课喽~
作者:
小小成很拽
时间:
2015-9-15 22:29
folat存储的数据范围大
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2