3 回答

TA贡献69条经验 获得超36个赞
其实这涉及到精度的问题,容我慢慢道来:
一般的小数,比如1.5,2.5,0.5,在java里面,这些都默认属于double类型的数据,我们都知道float类型是4字节,也就是32位,double是8个字节,也就是64位,所以我们一般在定义float函数的时候,比如:float a = 0.1; 是会报错的,因为这样java虚拟机认为会丢失精度(把一个64位的数据,赋值给32位的数据),所以不能通过!必须加f 强制转换为float类型;
再来看下你的第一个问题:
参数a 是float类型,然后参数b也是float类型,最后(a+b)/2 还是float类型。
所以,把一个float类型 的数据赋值给一个float类型没错;
第二个问题:
a是整数,b是整数,c=a+b,所以c还是整数,c/2,最后还是整数,所以(94+81)=175,175/2=87.5,但是由于c/2是一个整数,所以87.5会强制转换为87,最后把一个整数87赋值给double类型,所以又变成87.0。
你可以再试一下,输出一下c/2,就是87;
你也可以试一下,把c/2改成c/2.0 就会输出87.5

TA贡献69条经验 获得超36个赞
首先,参数a 是float类型,然后参数b也是float类型,最后(a+b)/2 还是float类型。
所以,把一个float类型 的数据赋值给一个float类型有错吗?显然没有啊
添加回答
举报