jdk1.7之后,常量池被放到了堆空间中,这使得intern()的实现原理也不同了。
String a = new String("1") + new String("2");
System.out.println(a.intern() == a);
System.out.println(a == "12");
得到的结果是true,true.
String b = "12";
String a = new String("1") + new String("2");
System.out.println(a.intern() == a);
System.out.println(a == "12");
得到的结果是false,false.
这是因为在第一段代码中,new String("1")和 new String("2")会在常量池和堆中生成字符串对象1和2;
而String a = new Stirng("1") + new String("2")则会堆中生成字符串12(而在常量池中没有),
在jdk1.6之前a.intern()会将字符串复制到常量池中,而jdk1.7之后,如常量池不存在a,则在内存中找,如果内存中有,就在常量池中保存一个指向内存中对象的引用。
那么在第一段代码中“12”在内存中不存存在,a.intern()返回的是a的引用,则a.intern == a肯定为true.
在第二段代码中String b = "12";会将“12”放在常量池中,那么a.intern()返回的是常量池中的引用,而a是内存中引用,两都肯定不相等了。
最后判断的就是a是否和常量池中的“12”相等。通过前面的分析相信会有答案了。