1.请问大家这段代码为什么正确public void calcAvg(float a,float b){ float avg=(a+b)/2; System.out.println("平均分:"+avg);}不是讲使用float赋值的时候要在后边加f吗.这个没有加为什么正确2.请问为什么这个输出结果是87.0.不应该是87.5吗/端点调试功能我怎么调也是输出结果就变成87.0.请教大家这是为什么public class 数组 { public static void main(String[] args) { // 创建对象,对象名为hello 数组 hello = new 数组(); // 调用方法,传入两门课程的成绩 hello.calcAvg(94, 81); } public void calcAvg(int a,int b){ int c=a+b; double avg=c/2; System.out.println("平均分"+avg); }}
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类型有错吗?显然没有啊
添加回答
举报
0/150
提交
取消