Java赋值运算符中关于强转的一个面试题

本文通过两个具体的代码示例,深入探讨了Java中short类型变量在进行算术运算时的自动类型提升现象及其解决方法。解释了为何直接相加会导致编译错误,而使用复合赋值操作符则可以避免该问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

话不多说,直接上面试题:
short s = 1;s = s + 1;
short s = 1;s += 1;
问:上面两个代码有没有问题,如果有,那么问题在哪里?
我们把上面的代码放入eclipse中运行,不难发现第一个是有问题的,而第二个是没有问题的。
第一个有问题的原因:我们认真分析代码不难得出,s是short类型,而1是int类型,他们两相加,会发生向上转型,自动转为int类型,所以右面的结果是一个int类型的值,而左边是short类型,故而报错。
但是,在我们往常的理解中,s += 1好像就是s = s + 1;那么,为什么为什么换成第二个就没问题呢?
原因是:扩展的赋值运算符其实隐含了一个强制类型转换!
此处s += 1;不是等价于s = s + 1;而是等价于s = (s的数据类型)(s + 1);
有隐藏的强转在其中,故而第二个是没有问题的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值