在 Java 中声明 Final 时使用 == 比较字符串
在 Java 中,== 运算符比较两个对象的内存引用。但是,当字符串被声明为 Final 并使用编译时常量初始化时,会出现独特的行为。
场景 1:非 Final 字符串
考虑以下代码段:
String str1 = "str"; String str2 = "ing"; String concat = str1 + str2; System.out.println(concat == "string");
此代码的结果将为 false。连接操作创建一个新的 String 对象,它不等于预先存在的字符串文字“string”。
场景 2:最终字符串
现在,让我们将字符串声明为最终字符串:
final String str1 = "str"; final String str2 = "ing"; String concat = str1 + str2; System.out.println(concat == "string");
令人惊讶的是,结果现在是 true。这是因为将字符串声明为 Final 允许编译器内联它们的值并将整个表达式视为编译时常量表达式。
编译器优化:实习
当编译时常量表达式涉及字符串时,Java 虚拟机 (JVM) 会对其进行“实习”,这意味着它将字符串的唯一实例存储在称为字符串池的特殊位置中。因此,第二个场景中的连接字符串直接与中间字符串“string”进行比较,得到真实的结果。
结论
将字符串声明为最终的编译时常量导致优化器将表达式视为单个 String 对象,从而允许对预先存在的字符串文字进行语法相等性检查 (==)。这演示了 Java 中的编译器优化以及它如何影响对象标识比较。
以上是在 Java 中将字符串声明为'final”是否会改变'==”比较它们的方式?的详细内容。更多信息请关注PHP中文网其他相关文章!