一直以来 == 和 equals 方法都是比较容易混淆的地方。
下面通过这段代码来进行比较
package mypack.test;
public class TestEquals {
/**
* @param args
*/
public static void main(String[] args) {
String s1 = new String("tom");//"tom";
String s2 = new String("tom");//"tom";
String s3 = "tom";//s1;
System.out.println(s1+" "+s2+" "+s3);
if (s1 == s2)
System.out.println("s1 == s2");
else
System.out.println("s1 != s2");
if (s1.equals(s2))
System.out.println("s1 equals s2");
else
System.out.println("s1 doesnt equals s2");
if (s1 == s3)
System.out.println("s1 == s3");
else
System.out.println("s1 != s3");
if (s1.equals(s3))
System.out.println("s1 equals s3");
else
System.out.println("s1 doesnt equals s3");
s3 = "mike";
System.out.println(s1+" "+s2+" "+s3);
}
}
输出的结果为
tom tom tom
s1 != s2
s1 equals s2
s1 != s3
s1 equals s3
tom tom mike
然而将代码进行一些修改:
package mypack.test;
public class TestEquals {
/**
* @param args
*/
public static void main(String[] args) {
String s1 = "tom";
String s2 = "tom";
String s3 = "s1;
System.out.println(s1+" "+s2+" "+s3);
if (s1 == s2)
System.out.println("s1 == s2");
else
System.out.println("s1 != s2");
if (s1.equals(s2))
System.out.println("s1 equals s2");
else
System.out.println("s1 doesnt equals s2");
System.out.println(s1+" "+s2+" "+s3);
}
}
输出的结果则是:
tom tom tom
s1 == s2
s1 equals s2
mike tom mike
在这里,我们可以做如下解释:
1.在java中 == 和 未经覆盖的equals方法,都是按照地址进行比较的。
2.java中,String类和java包装类,比如Byte,Integer等,都对equals方法进行了覆盖。覆盖后的equals方法,是按照内容进行比较的,而不再是地址。因此,在例一和例二中的会显示s1 equals s2
3.在字符串初始化的时候,如果使用s1 = "tom", s2 = "tom",则这两个tom指向的时同一个地址。这里的tom类似于一个常量,无论被赋值给多少个字符串,都是同一个"tom"。因此,在例二中会显示"s1 == s2"
4.在字符串初始化的时候,如果使用s1= new String("tom"); s2 = new String("tom"),则两个"tom"被分配在两个不同的内存地址。因此在例一中,会显示"s1 != s2"