猿问

关于java中float型的问题

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);

}}


















hy_wang
浏览 2018回答 3
3回答

黄小凡

其实这涉及到精度的问题,容我慢慢道来:一般的小数,比如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    

黄小凡

首先,参数a 是float类型,然后参数b也是float类型,最后(a+b)/2 还是float类型。所以,把一个float类型 的数据赋值给一个float类型有错吗?显然没有啊
随时随地看视频慕课网APP

相关分类

Java
我要回答