输出下列代码的执行结果:
public class Test1 {
public static void main(String[] args) {
String s1 = "Hello";
String s2 = "Hello";
String s3 = "Hel" + "lo";
String s4 = "Hel" + new String("lo");
String s5 = new String("Hello");
String s6 = s5.intern();
String s7 = "H";
String s8 = "ello";
String s9 = s7 + s8;
System.out.println(s1 == s2); //true
/*字面量创建字符串会先在字符串池中找,看是否有相等的对象,没有的话就在堆中创建,把地址驻留在字符串池;有的话则直接用池中的引用,避免重复创建对象。*/
System.out.println(s1 == s3); //true
/*s3是一个字符串拼接操作,参与拼接的部分都是字面量,编译器会进行优化,在编译时s3就变成“Hello”了,所以s1==s3。*/
System.out.println(s1 == s4); //false
/*s4虽然也是拼接,但“lo”是通过new关键字创建的,在编译期无法知道它的地址,所以不能像s3一 样优化。所以必须要等到运行时才能确定,必然新对象的地址和前面的不同。*/
System.out.println(s1 == s9); //false
/*s9是两个变量拼接,编译期无法确定 Hello的地址值。也就是先创建了"H"对象,再创建了"ello"对象,最后拼接起来.*/
System.out.println(s4 == s5); // false
/*都新创建了对象,地址值肯定不一样!*/
System.out.println(s1 == s6); //true
/*s6利用intern()方法得到了s5在字符串池的引用,并不是s5本身的地址。由于它们在字符串池的引用都指向同一个“Hello”对象,自然s1==s6。*/
}
}
补充:? s.intern();? ??? ? ?取s关联的字符串(Hello)的地址值?
再次总结一下: 字面量创建字符串会先在字符串池中找,看是否有相等的对象,没有的话就在堆中创建,把地 址驻留在字符串池;有的话则直接用池中的引用,避免重复创建对象。
new关键字创建时,前面的操作和字面量创建一样,只不过最后在运行时会创建一个新对 象,变量所引用的都是这个新对象的地址。
(小编也在努力学习更多哟!以后会多多分享哒!)
希望对友友们有所帮助!!!!
|