为什么
char ch = '4'; ch = '4' + 2;
工作,但是
char ch = '4'; ch = ch + 2;
不是吗
为了理解这一点,让我们考虑一下编译器在两种可能性下每个步骤所做的事情。让我们开始:
ch = '4' + 2;
编译器将‘4’转换为int。所以变成
ch = 52 + 2;
然后编译器变成
ch = 54;
ch是一个字符,编译器可以将54转换为字符,因为它可以证明转换没有损失。
现在让我们考虑第二个版本:
ch = ch + 2;
ch在编译时没有已知值。因此,这成为
ch = ((int) ch) + 2;
现在,编译器无法证明此(int)的结果在char范围内可存储。因此它 不会 自动缩小范围,并报告为错误。
编辑1:
如果编译器可以证明该变量永远不会改变,并且是可内联的。然后可以将第二种形式转换为第一种形式。Subir指出,添加“ final”可以实现这一点。尽管如果编译器要执行更改分析,那么从技术上讲,它无需使用final关键字就能解决此问题,但是final确实使编译器和代码阅读者更容易进行操作。
编辑2:
Java语言规范中涵盖了将int缩小为char的情况,该链接由Jon Skeet提供。