32 intern_1.8
串池可以避免重复创建对象;
字符串变量拼接,stringbuilder;
动态拼接的字符串,
动态创建的ab值,放入串池中;
s.intern();
情况1
public class Demo23 {
public static void main(String[] args) {
//[a b ab]
String s=new String("a")+new String("b");
//将这个字符串对象尝试放入串池,如果有则不放入,如果没有则放入,会把串池中对象返回。
String s2=s.intern();//不存在,创建ab并放入串池。
System.out.println(s2=="ab");
System.out.println(s=="ab");
}
}
情况2代码
public class Demo23 {
public static void main(String[] args) {
String x="ab";
String s=new String("a")+new String("b");
//将这个字符串对象尝试放入串池,如果有则不放入,如果没有则放入,会把串池中对象返回。
String s2=s.intern();//从串池中可以获取到,不创建。
System.out.println(s2==x); //true
System.out.println(s==x); //false
}
}
33 intern_1.6
34 StringTable面试题
35 StringTable位置
1.7 常量池从永久代转移到堆中。
永久代的效率低,触发时间很晚,stringtable应用的很广泛,回收效率不高,问题很大。
只需要minorgc就进行回收,减轻了字符串对内存的占用。
36 StringTable位置
1.6下实验
-XX:MaxPermSize=10m
1.8下
设置堆的最大内存、
-Xmx10m
出现oom异常,没有出现堆内存不足。
GC overhead limit exceeded。
垃圾回收规则,如果98%不足以挽回2%的空间,就不放弃。
关闭
出现java Heap space。
37 StringTable垃圾回收
字符串常量也可以被垃圾回收。
1、设置虚拟机参数。
底层类似于哈希表实现,数组+链表
桶,buckets,