黑马程序员技术交流社区

标题: 关于JAVA基础中的float类型数据与int类型数据的运算 [打印本页]

作者: TTc    时间: 2014-4-10 23:40
标题: 关于JAVA基础中的float类型数据与int类型数据的运算
本帖最后由 TTc 于 2014-4-11 11:37 编辑

float型数据是有4个8位的二进制位,int类型也是4个8位的二进制位,当float与int型数据相加时得到的结果是float类型的数据。老师说这是因为float多了一个小数点的缘故。但是我 不明白在java数据类型的提升过程中为什么就因为float类型数据多了一个小数点就会将float型数据相加的int型数据的结果转换为float呢?这两个类型的变量不都是4个字节的吗?
作者: 491138002    时间: 2014-4-10 23:49
本帖最后由 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位整数大很多。
作者: TTc    时间: 2014-4-11 00:43
491138002 发表于 2014-4-10 23:49
int是精确值类型,float是近似值类型。
int的取值范围是:-2^31 ~ 2^31 - 1,这里32位中第一位是符号位,剩 ...

谢谢,我想明白了,脑筋没转过弯来,多了一个小数点,小数点后面多了一个数肯定是比没有小数点的数大的。呵呵




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2