舉例說明:
String str2 = new String("str")+new String("01");
str2.intern();
String str1 = "str01";
System.out.println(str2==str1);
在JDK 1.7下,當(dāng)執(zhí)行str2.intern();時,因為常量池中沒有“str01”這個字符串,所以會在常量池中生成一個對堆中的“str01”的引用(注意這里是引用 ,就是這個區(qū)別于JDK 1.6的地方。在JDK1.6下是生成原字符串的拷貝),而在進(jìn)行String str1 = “str01”;字面量賦值的時候,常量池中已經(jīng)存在一個引用,所以直接返回了該引用,因此str1和str2都指向堆中的同一個字符串,返回true。
String str2 = new String("str")+new String("01");
String str1 = "str01";
str2.intern();
System.out.println(str2==str1);
將中間兩行調(diào)換位置以后,因為在進(jìn)行字面量賦值(String str1 = “str01″)的時候,常量池中不存在,所以str1指向的常量池中的位置,而str2指向的是堆中的對象,再進(jìn)行intern方法時,對str1和str2已經(jīng)沒有影響了,所以返回false。
---------------------
以上是一篇帖子的陳述,我為了保證環(huán)境的一致性,分別在jdk 1.6 ,1.7, 1.8環(huán)境下做了測試,發(fā)現(xiàn)結(jié)果都是一致的,與上文中表述的觀點有出入,即將中間兩行調(diào)換位置后結(jié)果為false的結(jié)論。
其實我們可以看看intern()方法的源碼解釋:

這方法是個native方法,并不是由java來實現(xiàn)的,我們可以看到紅色箭頭所指的那段話,只要s1.equals(s2)為true,那么s1.intern()就等于s2.intern(),而String s="a"; s與s.intern()是恒等的,所以最后比的就是內(nèi)容罷了,
并不是調(diào)換了順序,就導(dǎo)致引用不一樣而返回false。