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

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

本帖最后由 TTc 于 2014-4-11 11:37 编辑

float型数据是有4个8位的二进制位,int类型也是4个8位的二进制位,当float与int型数据相加时得到的结果是float类型的数据。老师说这是因为float多了一个小数点的缘故。但是我 不明白在java数据类型的提升过程中为什么就因为float类型数据多了一个小数点就会将float型数据相加的int型数据的结果转换为float呢?这两个类型的变量不都是4个字节的吗?

点评

其实两个基本类型的数据运算,运算完之后,会自动转换成大的类型,比如 int+long=long ,赌不赌  发表于 2014-4-11 08:02

评分

参与人数 1黑马币 +1 收起 理由
枫儿 + 1 赞一个!

查看全部评分

3 个回复

正序浏览
491138002 发表于 2014-4-10 23:49
int是精确值类型,float是近似值类型。
int的取值范围是:-2^31 ~ 2^31 - 1,这里32位中第一位是符号位,剩 ...

谢谢,我想明白了,脑筋没转过弯来,多了一个小数点,小数点后面多了一个数肯定是比没有小数点的数大的。呵呵
回复 使用道具 举报
本帖最后由 491138002 于 2014-4-10 23:50 编辑

int是精确值类型,float是近似值类型。
int的取值范围是:-2^31 ~ 2^31 - 1,这里32位中第一位是符号位,剩下的31位是表示数值的。
而float的组成是:1位符号位+8位指数(q)+23位底数(b),其解释出来的形式是:b^q,由于指数q是8位有符号整数,范围是-128 ~ 127,23位的底数(无符号)最大值就是2 ^ 23,算上指数的话,最大可以表达到2 ^ 23 ^ 127,但是由于计算机的运算能力限制,并不能处理到如此大的数,但是其取值范围也会比32位整数大很多。

评分

参与人数 1技术分 +1 收起 理由
枫儿 + 1 赞一个!

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马