为了账号安全,请及时绑定邮箱和手机立即绑定

关于java中float型的问题

关于java中float型的问题

hy_wang 2017-07-10 19:52:00
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

    

查看完整回答
3 反对 回复 2017-07-10
  • hy_wang
    hy_wang
    有点看不懂..这个float a=0.1 float不是单浮点吗 这不是刚好一个小数点.刚好满足吗,怎么会判断丢失精度.那么照你这样说的话float到底应该什么时候加f什么时候不加f...因为我不讷讷个判断究竟一位小数的时候什么时候丢失什么时候不丢失 2.第二个问题请问也是涉及精度所以变成2.0就好了吗,我的疑问是我都已经定义avg是double型了,在我的理解力一个整数175/2不是87.5,刚好我定义为double型它不是就应该显示87.5吗..非常感谢你
  • hy_wang
    hy_wang
    搞懂了,非常感谢!
?
黄小凡

TA贡献69条经验 获得超36个赞

首先,参数a 是float类型,然后参数b也是float类型,最后(a+b)/2 还是float类型。

所以,把一个float类型 的数据赋值给一个float类型有错吗?显然没有啊

查看完整回答
反对 回复 2017-07-10
  • 3 回答
  • 0 关注
  • 2017 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信