在比较对象时候,常常用到"=="和"equals(Object)"。它们常常让初学者感到疑惑。下面先看一个例子
publicclassExample1
{
publicstaticvoidmain(String[]args)
{
Strings1=newString("abc");
Strings2=newString("abc");
//s1=s2;
System.out.println("用==比较结果");
System.out.println(s1==s2);//false
}
}
既然两个String对象内容同为"abc"为什么先打出false呢。那是由于"=="比较的是两个对象的引用(references),并不是他们的内容,怎么才能比较内容是否相等呢?去掉s1=s2一句的注释符结果就不同了,因为他们的引用相同了。
我们要使用equals(Object)方法,由于equals(Object)方法为Object类中定义的方法,所用按照默认方式定义过的类均是其子类。也就是说Object类为所有类的超类(superclass,也叫父类、基类等),在Object中的equals(Object)方法其标准形式为
publicbooleanequals(Objectobj)
返回类型为boolean,即true/false与"=="返回类型一样。Object类中定义的equals(Object)方法是直接使用"=="比较的两个对象,所以在没有覆盖(override,或称改写、重写)equals(Object)方法的情况下,equals(Object)与"=="一样是比较的引用。如下例(结果在注释中):
publicclassExample4
{
publicstaticvoidmain(String[]args)
{
Example4e=newExample4();
Example4e4=newExample4();
System.out.println("用equals(Object)比较结果");
System.out.println(e.equals(e4));//结果为false
System.out.println("用==比较结果");
System.out.println(e==e4);//结果为false
}
}
equals(Object)方法与"=="相比的特殊之处就在于它可以覆盖,所以我们可以通过覆盖的办法让它不是比较引用而是比较数据内容。当然JDK中也有覆盖过equals(Object)方法的类,如java.lang.String,它就覆盖了从Object继承来的的equals(Object)方法,用以比较字符串内容是否相同。看看下面这个例子:
publicclassExample1
{
publicstaticvoidmain(String[]args)
{
Strings1=newString("abc");
Strings2=newString("abc");
System.out.println("用==比较结果");
System.out.println(s1==s2);//false
System.out.println("用equals(Object)比较结果");
System.out.println(s1.equals(s2));//true
}
}
例中用equals(Object)比较结果为true。用==比较结果为false。String.equals(Object)方法直接比较了两个字符串的内容,如果相同则返回true,否则返回false。你可以尝试把其中一个"abc"改成"abcde",看看结果有何变化。
publicclassExample1
{
publicstaticvoidmain(String[]args)
{
Strings1=newString("abc");
Strings2=newString("abc");
//s1=s2;
System.out.println("用==比较结果");
System.out.println(s1==s2);//false
}
}
既然两个String对象内容同为"abc"为什么先打出false呢。那是由于"=="比较的是两个对象的引用(references),并不是他们的内容,怎么才能比较内容是否相等呢?去掉s1=s2一句的注释符结果就不同了,因为他们的引用相同了。
我们要使用equals(Object)方法,由于equals(Object)方法为Object类中定义的方法,所用按照默认方式定义过的类均是其子类。也就是说Object类为所有类的超类(superclass,也叫父类、基类等),在Object中的equals(Object)方法其标准形式为
publicbooleanequals(Objectobj)
返回类型为boolean,即true/false与"=="返回类型一样。Object类中定义的equals(Object)方法是直接使用"=="比较的两个对象,所以在没有覆盖(override,或称改写、重写)equals(Object)方法的情况下,equals(Object)与"=="一样是比较的引用。如下例(结果在注释中):
publicclassExample4
{
publicstaticvoidmain(String[]args)
{
Example4e=newExample4();
Example4e4=newExample4();
System.out.println("用equals(Object)比较结果");
System.out.println(e.equals(e4));//结果为false
System.out.println("用==比较结果");
System.out.println(e==e4);//结果为false
}
}
equals(Object)方法与"=="相比的特殊之处就在于它可以覆盖,所以我们可以通过覆盖的办法让它不是比较引用而是比较数据内容。当然JDK中也有覆盖过equals(Object)方法的类,如java.lang.String,它就覆盖了从Object继承来的的equals(Object)方法,用以比较字符串内容是否相同。看看下面这个例子:
publicclassExample1
{
publicstaticvoidmain(String[]args)
{
Strings1=newString("abc");
Strings2=newString("abc");
System.out.println("用==比较结果");
System.out.println(s1==s2);//false
System.out.println("用equals(Object)比较结果");
System.out.println(s1.equals(s2));//true
}
}
例中用equals(Object)比较结果为true。用==比较结果为false。String.equals(Object)方法直接比较了两个字符串的内容,如果相同则返回true,否则返回false。你可以尝试把其中一个"abc"改成"abcde",看看结果有何变化。
博客主要讲解了Java中“==”和“equals(Object)”在比较对象时的区别。“==”比较的是对象引用,而“equals(Object)”默认也比较引用,但可通过覆盖该方法来比较数据内容,如JDK中的String类就覆盖了此方法用于比较字符串内容。

被折叠的 条评论
为什么被折叠?



