黑马程序员技术交流社区

标题: 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