A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

答:a,c,d正确;
4、 以下代码哪个是正确的?为什么?
a. byte b = 1 + 1;     
b. byte b = 1; b = b + 1;
c. byte b = 1; b = b += 1;   
d. byte b = 1; b = ++b;
选项a:
选项b中,b+1的结果默认转换为int型,int型不能直接转换为byte型,需强制转换。应改为:byte b=1;b=(byte)(b+1);
b=b+1是两次运算,b被提升为int型,运算结果为int,无法赋值给byte类型
选项c中,b+=1是一次运算,包含了一个隐藏的类型转换,相当于 b=(byte)(b+1);
选项d中,b=++b是一次运算,也包含了一个隐藏的类型转换

为啥我感觉第一个也是错的呀,谁能解释一下,水了,基础知识不老,

6 个回复

正序浏览
醉翁之意不在酒 来自手机 中级黑马 2015-7-19 00:54:38
7#
帖子為什麼是14年的,這論壇該怎麽看,才看的到最新的?
回复 使用道具 举报
头狼 发表于 2014-12-11 20:16
a是对的,因为右边是两个常量相加,它会判断是否在byte的取值范围里,如果在,就输出,如果超出byte的取值 ...

这个解释好,一直知道这个选项是对的,但是不知道为什么对
回复 使用道具 举报
我表示我也犯迷糊。。。
回复 使用道具 举报
不客气,我刚学基础,正好知道
回复 使用道具 举报
头狼 发表于 2014-12-11 20:16
a是对的,因为右边是两个常量相加,它会判断是否在byte的取值范围里,如果在,就输出,如果超出byte的取值 ...

谢谢,是这么回事!
回复 使用道具 举报
a是对的,因为右边是两个常量相加,它会判断是否在byte的取值范围里,如果在,就输出,如果超出byte的取值范围就会报错。我的理解。
回复 使用道具 举报 1 0
您需要登录后才可以回帖 登录 | 加入黑马