1.jdk1.6测试代码
String s1 = "str";
String s2 = new String("str");
System.out.println(s1==s2);
System.out.println(s1==s2.intern());
输出:false false
2.jdk1.7测试代码
String s1 = "str";
String s2 = new String("str");
System.out.println(s1==s2);
System.out.println(s1==s2.intern());
输出:false true
总结:
1.不使用intern()方法时,JDK1.6/1.7比较一样,都是字符串常量的引用(存在常量池)和字符串对象的引用(存在堆)比较false
2.JDK1.6的常量池在方法区中,创建String常量s1时,是将str的引用存储方法区的常量池中;使用new创建s2对象时,是将str对象的引用存储在堆中,JDK1.6时,使用intern方法只会查找常量池中的引用,由于s2的引用 存在堆中,所以s1==s2.intern()比较为false;
3.JDK1.7将常量池移到了堆中,在使用intern()方法时,会先去常量池中找s2的引用,如果没有找到,则去堆中找,如果找到则将s2的对象放入常量池,并返回str的引用,因为常量池已经存在s1的str常量,所有s2.intern()会直接返回是s1的引用,所以s1==s2.intern()比较为true;(s2.intern()是把“str”的引用丢入常量池中,因为常量池中已经存在“str”的引用,所以直接返回"str"的引用,所以s1==s2.intern())