A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

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?

8 个回复

倒序浏览
看取值范围,而且浮点型和整形数据的编码方式不一样。可以找相关的书籍看看
回复 使用道具 举报
这两种在底层用的是不同的存储方式,不能用简单的字节多少来判断了
回复 使用道具 举报
这个是因为浮点型和整型数据编码形式不一样
回复 使用道具 举报
深究起来有说头 float其实很大
回复 使用道具 举报
float直接赋值给int反而不行   我觉得只能这么理解  整型都是精确的数  把一个精确的数赋值给一个代表大致精度的浮点型   是可以接受的   浮点型本身的范围很大  但是把一个表示大致精度的浮点型赋值给精确的整型  那么必定是不够精确的咯

关于浮点型的准确度 可以用下面的语句试一下  看到结果你就知道了

                float f1 = 2000000000;
                float f2 = 2000000050;
                System.out.println(f1==f2);
回复 使用道具 举报
都是大神                  
回复 使用道具 举报
Liveei 中级黑马 2015-9-12 16:23:24
8#
基础班快结课喽~
回复 使用道具 举报
folat存储的数据范围大
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马