java中equals方法與==邏輯運(yùn)算符
在Java中,我們比較兩個對象時有兩種方法,一種是直接使用邏輯運(yùn)算符==號,還有一種就是用equlas()函數(shù),該函數(shù)在Object中就定義了,所以每個類都會有這個函數(shù),好了現(xiàn)在我們看看普通對象和字符串在使用這兩種比較方式有什么不同,看下面代碼,讀者可以猜猜看結(jié)果是什么:
public class Equals {
/**
* @param args
*/
public static void main(String[] args) {
Object o1 = new Object();
Object o2 = new Object();
Object o3 = o1;
Object o4 = o2;
System.out.println( "o1.equals( o1 ): " + o1.equals( o1 ) );
System.out.println( "o1.equals( o2 ): " + o1.equals( o2 ) );
System.out.println( "o1.equals( o3 ): " + o1.equals( o3 ) );
System.out.println( "o1.equals( o4 )" + o1.equals( o4 ) );
System.out.println();
System.out.println( "o1 == o1: " + ( o1 == o1 ) );
System.out.println( "o1 == o2: " + ( o1 == o2 ) );
System.out.println( "o1 == o3: " + ( o1 == o3 ) );
System.out.println( "o1 == o4: " + ( o1 == o4 ) );
System.out.println();
String s1 = new String( "abc" );
String s2 = new String( "abc" );
String s3 = new String( "def" );
String s4 = s1;
String s5 = s2;
String s6 = s3;
System.out.println( "s1.equals( s1 ): " + s1.equals( s1 ) );
System.out.println( "s1.equals( s2 ): " + s1.equals( s2 ) );
System.out.println( "s1.equals( s3 ): " + s1.equals( s3 ) );
System.out.println( "s1.equals( s4 ): " + s1.equals( s4 ) );
System.out.println( "s1.equals( s5 ): " + s1.equals( s5 ) );
System.out.println( "s1.equals( s6 ): " + s1.equals( s6 ) );
System.out.println();
System.out.println( "s1 == s1: " + ( s1 == s1 ) );
System.out.println( "s1 == s2: " + ( s1 == s2 ) );
System.out.println( "s1 == s3: " + ( s1 == s3 ) );
System.out.println( "s1 == s4: " + ( s1 == s4 ) );
System.out.println( "s1 == s5: " + ( s1 == s5 ) );
System.out.println( "s1 == s6: " + ( s1 == s6 ) );
}
}
有沒有答案了,如果有了,看看你的答案正確嗎,
o1.equals( o1 ): true
o1.equals( o2 ): false
o1.equals( o3 ): true
o1.equals( o4 )false
o1 == o1: true
o1 == o2: false
o1 == o3: true
o1 == o4: false
s1.equals( s1 ): true
s1.equals( s2 ): true
s1.equals( s3 ): false
s1.equals( s4 ): true
s1.equals( s5 ): true
s1.equals( s6 ): false
s1 == s1: true
s1 == s2: false
s1 == s3: false
s1 == s4: true
s1 == s5: false
s1 == s6: false
為什么會出現(xiàn)上面的結(jié)果呢,其實(shí)在Java中,邏輯運(yùn)算符==號在比較對象的時候是嚴(yán)格的比較這兩個對象是不是同一個對象,說白了,它比較的是兩個對象在內(nèi)存中的地址,只有當(dāng)兩個變量指向同一個內(nèi)存地址即同一個對象時才返回true,否則返回false,所以就可以看到當(dāng)我們用new方法創(chuàng)建了o1和o2由于分配了兩個不同的內(nèi)存空間,所以它們在用邏輯運(yùn)算符==號來判斷兩個對象是否相等時自然應(yīng)該返回的是false,而在比較o1和o3時,由于o3指向的實(shí)際是o1所指向的地址,所以返回true,在字符串中邏輯運(yùn)算符==的作用和普通對象是一樣的。
那么對于o1和o2用equals()方法比較返回的為什么也是false呢,我們來看一段代碼:
public boolean equals( Object o2 )
{
this == o2;
}
這是Object中equals()函數(shù)的實(shí)現(xiàn),可以看到實(shí)際上它的功能還是比較兩個對象的地址,自然你現(xiàn)在可以推出為什么o1和o2比較時還是返回false了。
那現(xiàn)在問題可能來了,那為什么s1和s2比較時返回的是true呢,他們在內(nèi)存空間的地址可是不一樣的啊,呵呵,其實(shí)這個理解起來更簡單了,因?yàn)樵赟tring類中重載了equals()函數(shù),使它比較的是兩個字符串的內(nèi)容,而不是兩個字符串對象在內(nèi)存中的地址,至于如何寫這個函數(shù)我就不多說了,大家可以自己寫寫看,實(shí)現(xiàn)方式有多種,不過Sun公司當(dāng)然只有那一種實(shí)現(xiàn)方式,哈哈