1.判断定义为String类型的s1和s2是否相等
String s1 = "abc"; String s2 = "abc"; System.out.println(s1 == s2); System.out.println(s1.equals(s2));
解答:
true,true
“==”比较的是基本类型值,比较的是引用类型地址,String是引用类型,所以是比较地址;equal,你是abc,我也是abc。就相等,字符序列相同就相等
2.下面这句话在内存中创建了几个对象?
String s1 = new String("abc");
解答:
2
在堆中new了一个对象,在常量池中创建了一个对象
3.判断定义为String类型的s1和s2是否相等
String s1 = new String("abc"); String s2 = "abc"; System.out.println(s1 == s2); System.out.println(s1.equals(s2));true
解答:
false,true
new会在堆和常量池中都创建对象,String 只在常量池中创建,所以地址不同
equals同上
4.判断定义为String类型的s1和s2是否相等
String s1 = "a" + "b" + "c"; String s2 = "abc"; System.out.println(s1 == s2); System.out.println(s1.equals(s2));
解答:
true,true
java中有常量优化机制,你存了abc,比较的也是abc,所以地址相同
Java常量优化机制:
1.如果常量池中有像创建的对象,则仅仅是将地址指向这个常量即可。
2.如果是几个字符组成的字符串,变成字符串常量的时候,也是遵循上一条规定;
equals同上
5.判断定义为String类型的s1和s2是否相等
String s1 = "ab"; String s2 = "abc"; String s3 = s1 + "c"; System.out.println(s3 == s2); System.out.println(s3.equals(s2));
解答:
false,true
常量优化只是针对常量,如果有变量的话就不能被优化
串联符号“+”通过StringBuffer缓冲将结构转化为一个toString,所以它有自己的地址值
String s3 = s1+“c”;这一句话,是在StringBuffer缓冲区中进行创建一个StringBuffer对象,将两者相加。但是对s3进行赋值时不能够直接将缓冲区的对象地址取来而是用toString方法变成另外的堆内存,然后赋值给s3,所以,s3和s2的地址值已经不同了。
equals同上