在Java中,字符串由于其不变性和实习特性在内存管理中发挥着独特的作用。这些概念不仅可以提高性能,还可以引入内存处理的细微差别,这在面试中通常是必不可少的。
让我们深入探讨垃圾收集和不变性,并注意字符串池和JVM内存管理如何与这些概念交互。
这篇文章建立在上一篇关于字符串池和内存管理的文章中讨论的概念的基础上。首先查看该文章将为理解此处涵盖的主题提供有用的基础。
在 Java 中,字符串文字在垃圾回收 (GC) 方面的行为有所不同。
1。字符串池中未引用的文字
String string3 = "World"; // Stored in String Pool // A new string is created in the pool due to case-sensitivity string3 = "WORLD";
在此示例中,原始“World”仍在字符串池中,即使 string3 重新分配。
JVM 在池中保留未引用的文字,允许将来重用,但这些文字不会像常规堆对象那样受到垃圾回收。
2。堆对象
String str1 = new String("World"); // Stored in Heap // String Pool reference is used now // leaving the previous "World" eligible for GC in Heap str1 = "WORLD";
使用 new 创建时,字符串会进入 堆而不是字符串池。
如果引用发生变化,就像 str1 一样,堆中未使用的“World”字符串可以被垃圾回收,因为它不再被引用。
Java 中的字符串不可变——一旦创建,就无法修改。任何“修改”都会产生一个新的字符串对象,而不是更改现有的字符串对象。
1。编译时串联(使用文字优化)
String string5 = "This" + "String";
当连接文字时,Java编译器通过在编译时执行连接来优化。
生成的字符串(“ThisString”)直接存储在字符串池中,完全避免了堆。
此过程也称为恒定池折叠。
2。运行时串联(无优化)
String string1 = "Hello"; string1 = string1 + "Hello"; // Stored in Heap
当一个或多个操作数是变量(非文字)时,连接发生在运行时,产生一个不驻留在字符串池中的堆对象.
示例:原始的“Hello”文字保留在池中,而串联的“HelloHello”字符串存储在堆中,确认了原始“Hello”的不变性。
3。使用 concat() 方法
String string3 = "World"; // Stored in String Pool // A new string is created in the pool due to case-sensitivity string3 = "WORLD";
4。应用 intern() 方法
String str1 = new String("World"); // Stored in Heap // String Pool reference is used now // leaving the previous "World" eligible for GC in Heap str1 = "WORLD";
过程:
首先,concat() 操作在 堆 中创建一个新字符串,其值为“World say Hello”,string3 最初引用该字符串。
当我们调用 intern() 时,它会检查该值是否已经在 字符串池 中。如果没有,它将将该值添加到池中并返回对该池实例的引用。
调用 intern() 后,string3 指向字符串的池化副本。原始堆实例现在没有任何活动引用,可以进行垃圾回收,从而减少不必要的内存使用。
通过理解和利用这些原则,Java 开发人员可以编写内存效率更高、性能更高的代码。
编码快乐!
以上是字符串:Java 中的垃圾收集和不变性的详细内容。更多信息请关注PHP中文网其他相关文章!