开发者社区> 问答> 正文

关于java的精度损失问题

以下代码应该会报错精度损失:

byte a =1;
byte b =2;
byte i = a +b;

但是,为什么下面这个编译时不报错?

float a = 1.2f;
float b = 2;
float i = a + b;

究竟为什么?等号右自动转换成double,赋值给float不会损失精度?

展开
收起
蛮大人123 2016-03-18 16:58:25 3308 0
1 条回答
写回答
取消 提交回答
  • 我说我不帅他们就打我,还说我虚伪

    等号右边相加的结果,不是double,是float所以不会有经度损失。
    `float a = 1.2f; //1行
    float b = 2; //2行
    float i = a + b; //3行`
    小数默认是double型,但是1行你指定了是float型(1.2f),2行是一个int,所以3行右边的结果,是float,不是double,所以不会经度损失。
    如果,1行不加f,编译会报错(小数默认是double型)。

    2019-07-17 19:06:58
    赞同 展开评论 打赏
问答分类:
问答标签:
问答地址:
相关产品:
问答排行榜
最热
最新

相关电子书

更多
Spring Cloud Alibaba - 重新定义 Java Cloud-Native 立即下载
The Reactive Cloud Native Arch 立即下载
JAVA开发手册1.5.0 立即下载