- class OperateDemo2
- {
- public static void main(String[] args)
- {
- byte b = 1;
- byte b0 = 127;
- b += b0;//可以运行,值为-128;
- b = b+b0;//可能损失精度;
- int i = 1;
- int i0 = Integer.MAX_VALUE;
- i = i+i0;
- i += i0;
- System.out.println(i);
- short s = 1;
- short s1 = 32767;
- s += s1;//值为-32768
- s = s+s1;//可能损失精度
- System.out.println(s);
- }
- }
复制代码 对于byte,short,一个损失精度,一个溢出,而对于int,long,float,double则不会出现精度丢失的状况,为什么?
byte b = 1,这个1是默认int类型的,而byte和short类型的精度都小于int,那么b = b + b0、s = s+s1自然不会编译通过,需要强制转换(byte)。
Java 语言规范中讲到,复合赋值 E1 op= E2 等价于简单赋值E1 =(T)((E1)op(E2)),其中T 是E1 的类型。所以你例子中的 b += b0; 等价于 b = (byte)(b + b2);能编译通过,只是隐性转换类型。
int,long,float,double精度大于等于默认赋值时的int类型,自然不会强制要求类型转换 |