字符串常量池:深入检查
Java 中的字符串常量池被池化以优化内存使用并增强性能。这意味着当遇到字符串文字时,编译器会检查字符串常量池中是否存在具有相同值的现有字符串对象。如果找到,引用将定向到现有对象,避免创建新对象。
但是,当使用“new”运算符创建新的 String 对象时,会出现混乱,因为这似乎与规则相矛盾实习的。为了澄清这一点,让我们检查以下语句:
这些语句表明,当 String 文字被保留并存储在池中时,使用“new”会强制 JVM 创建一个新的 String 对象。这意味着,尽管池中存在等效的 String,“new”运算符会绕过它并在非池内存中分配一个新对象。
为了说明这一点,请考虑以下示例:
String one = new String("test"); String two = "test"; System.out.println(one.equals(two)); // true System.out.println(one == two); // false
正如预期的那样,“one”和“two”的值都是“test”,但是“==”比较返回 false,因为它们引用了不同的 String 对象。这是因为使用“new”会强制为“one”创建一个新的字符串对象,即使字符串文字“test”已经存在于池中。
总而言之,字符串常量池优化内部字符串文字的内存使用情况。但是,使用“new”会绕过池并在非池内存中创建一个新的 String 对象。这会产生两个不同的 String 对象,它们具有相同的值但不同的引用。
以上是字符串常量池:为什么即使文字存在,'new”也会创建一个新的字符串对象?的详细内容。更多信息请关注PHP中文网其他相关文章!