字符串常量池
字面量创建形式,String str1 = “droid”; JVM检测这个字面量,这里我们认为没有内容为droid的对象存在。JVM通过字符串常量池查找不到内容为droid的字符串对象存在,那么会创建这个字符串对象,然后将刚创建的对象的引用放入到字符串常量池中,并且将引用返回给变量str1
intern之后放入常量池
JDK7中的HotSpot VM没有把String常量放到native memory,而是把 interned String => Java heap ,把 Symbols => native memory
关于intern
在JDK6之前,常量池属于永久区的一部分,但在JDK7之后,被移动到堆中进行管理。String.intern()方法获得在常量池中的符号引用,如果常量池中没有该常量字符串,该方法会将字符串加入常量池。虽然String.intern方法的返回值永远等于字符串常量,但是不代表在系统的每时每刻,相同的字符串的intern返回都是一样的。(虽然在95%以上的情况下,都是相同的)。因为存在一种可能:在一次intern之后,该字符串在某一时刻被回收之后,再进行一次intern调用,那么字面量相同的字符串重新被加入常量池,但是引用位置已经不同。
问题
方法中new的String对象,在方法执行完之后,所引用的String对象还在么?