快捷导航

关于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);        }}

免责声明:本内容仅代表回答者见解不代表本站观点,请谨慎对待。

版权声明:作者保留权利,不代表本站立场。

回复

使用道具 举报

参与会员2

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