4、 以下代码哪个是正确的?为什么?
a. byte b = 1 + 1; 正确 。因为右边是两个常量相加,它会判断是否在byte的取值范围里,
如果在,就输出,如果超出byte的取值范围就会报错。
b. byte b = 1; b = b + 1; 错误 。因为b+1的结果默认转换为int型,int型不能直接转换为byte型,需强制转换。
应改为:byte b=1;b=(byte)(b+1);
c. byte b = 1; b = b += 1; 正确 。因为b+=1是一次运算,包含了一个隐藏的类型转换,相当于 b=(byte)(b+1);
d. byte b = 1; b = ++b;正确。因为b=++b是一次运算,也包含了一个隐藏的类型转换
c和d有区别吗?在哪里? |
|