String不同拼接操作的对比
- 常量与常量的拼接结果是在常量池中,且常量池不会存在相同内容的常量
- 只要其中有一个是变量,结果就在堆中(也就是会通过new产生,那么也就说明只要其中有一个是变量,那么就会在堆内存中去创建一个独一无二的对象,这个对象的地址自然也就是独一无二的)
- 如果拼接的结果调用了intern()方法,返回值就在一定在常量池中
- 如果一个堆中的字符串对象调用这个intern()方法,那么返回的结果就会是字符串常量池中和这个堆中对象的value值一样的对象(也就是返回了一个字符串常量池中的字符串对象)
如何判断自己是不是懂了:
这里有一道题:做对了就懂了:
public class Demo{
public static void main(){
String s1="javaEE";
String s2="hadoop";
String s3="javaEEHadoop";
String s4="javaEE"+"hadoop";
String s5=s1+"hadoop";
String s6="javaEE"+s2;
String s7=s1+s2;
String s8=s7.intern();
System.out.println(s3==s4);
/*
这里的输出结果为true,原因是:s4是的字符串运算时两边都是字符串常量,那么这个新对象是从字符串常量池中产生的,而s3是字面量赋值直接创建的对象,s3对象也是从字符串常量池中产生的,并且这两个值相等,所以这个时候输出的结果为true
*/
System.out.println(s3==s5);
/*
这里输出的结果为false,因为这里s5是有一边是变量连接的,所以就会从堆空间区产生这个新的对象,这个时候我们的这个值也就独一无二的,所以比较的结果肯定就是false
*/
System.out.println(s3==s7);
/*
这里的输出结果也为false
*/
System.out.println(s5==s6);
/*
这里的输出结果也为false
*/
System.out.println(s8==s3);
/*
这里输出的结果为true,因为这里我们的s8对象产生是s7对象调用了intern()方法之后产生的,那么这个时候的s8对象其实就是从字符串常量池中产生的了,那么这个时候由于s3也是从字符串常量池中产生的,所以这个时候的结果就应该为true
*/
System.out.println(s8==s7);
/*
这里输出的结果为false,因为这里的s7还是通过了变量连接的,那么这个时候的s7是独一无二的,那么也就说明这个时候的结果就应该为true
*/
//判断一下上面的输出结果都是什么
}
}