字符串常量池:了解 Interning 和“新”运算符
在 Java 中,字符串文字(例如“abc”)会被 interned ,这意味着它们存储在字符串常量池中,并且对它们的引用是共享的。然而,当使用“new”运算符创建一个新的 String 对象时,会在内存中创建一个新对象,而不是引用池中的现有对象。
关于此行为的冲突陈述导致了误解。虽然 JVM 在遇到文字时会检查池中是否存在现有字符串,但此检查仅适用于实际保留的字符串。如果在非池内存中引用文字(使用“new”),则会创建一个新对象,即使池中已存在匹配的字符串。
为了说明这一点,请考虑以下代码:
<code class="java">String one = new String("test"); String two = "test";</code>
“test”是一个被保留的文字,因此对它的引用已经在池中。然而,当使用“new”创建一个新的 String 对象时,会在内存中分配一个新的 String 对象,这意味着它具有与两个不同的引用。
<code class="java">System.out.println(one.equals(two)); // true System.out.println(one == two); // false</code>
equals() 方法比较字符串的值,这是相同的,但 == 运算符比较它们的引用,这是不同的。
暗示使用“new”创建的字符串仍放置在池中的语句可能会引起混淆,但这是误导性的。虽然与文字具有相同值的字符串可能存在于内存中的某个位置,但它不会添加到池中,并且无法通过文字本身访问。
因此,当使用“new”运算符时,JVM在内存中创建一个新的 String 对象,而不是返回对池中现有对象的引用,即使存在具有相同值的对象。
以上是为什么“new String()”会创建一个新对象,即使字符串常量池中已经存在具有相同值的字符串?的详细内容。更多信息请关注PHP中文网其他相关文章!