equals()方法和“==”運(yùn)算符比較

equals()方法和“==”運(yùn)算符比較

首先籠統(tǒng)的來講“java中equals()方法和“==”運(yùn)算符” ?都是比較的地址,那為什么我們?cè)谑褂弥锌倳?huì)出現(xiàn)混淆的情況呢老是弄錯(cuò)呢,這是因?yàn)椤爸貙慹quals()方法”和一些 “特殊情況”的存在。

有兩種用法說明:

1)對(duì)于字符串變量來說,使用“==”和“equals()”方法比較字符串時(shí),其比較方法不同。

“==”比較兩個(gè)變量本身的值,即兩個(gè)對(duì)象在內(nèi)存中的首地址。

  “equals()”比較字符串中所包含的內(nèi)容是否相同。

比如:

String s1,s2,s3 = "abc", s4 ="abc" ;

s1 = new String("abc");

s2 = new String("abc");

那么:

s1==s2?是false????? //兩個(gè)變量的內(nèi)存地址不一樣,也就是說它們指向的對(duì)象不?一樣,故不相等。

s1.equals(s2)?是true???? //兩個(gè)變量的所包含的內(nèi)容是abc,故相等。

注意(1)

如果:StringBuffer s1 = new StringBuffer("a");

StringBuffer s2 = new StringBuffer("a");

結(jié)果:s1.equals(s2) //是false

解釋:StringBuffer類中沒有重新定義equals這個(gè)方法,因此這個(gè)方法就來自O(shè)bject類,而Object類中的equals方法是用來比較“地址”的,所以等于false.

注意(2)

對(duì)于s3和s4來說,有一點(diǎn)不一樣要引起注意,由于s3和s4是兩個(gè)字符串常量所生成的變量,其中所存放的內(nèi)存地址是相等的,所以s3==s4是true(即使沒有s3=s4這樣一個(gè)賦值語句)

2)對(duì)于非字符串變量來說,"=="和"equals"方法的作用是相同的都是用來比較其對(duì)象在堆內(nèi)存的首地址,即用來比較兩個(gè)引用變量是否指向同一個(gè)對(duì)象。

比如:

class A

{

????? A obj1?? =??? new A();

????? A obj2?? = new A();

}

那么:obj1==obj2是false

obj1.equals(obj2)是false

但是如加上這樣一句:obj1=obj2;

那么obj1==obj2?是true

obj1.equals(obj2)?是true

總之:equals方法對(duì)于字符串來說是比較內(nèi)容的,而對(duì)于非字符串來說是比較其指向的對(duì)象是否相同的。

==?比較符也是比較指向的對(duì)象是否相同的也就是對(duì)象在對(duì)內(nèi)存中的的首地址。

String類中重新定義了equals這個(gè)方法,而且比較的是值,而不是地址。所以是true。

注意:

如果是基本類型比較,那么只能用==來比較,不能用equals

publicclass TestEquals {publicstaticvoid main(String[] args)

{inta = 3;intb = 4;intc = 3;

System.out.println(a == b);//結(jié)果是falseSystem.out.println(a == c);//結(jié)果是trueSystem.out.println(a.equals(c));//錯(cuò)誤,編譯不能通過,equals方法//不能運(yùn)用與基本類型的比較}

}

對(duì)于基本類型的包裝類型,比如Boolean、Character、Byte、Shot、Integer、Long、Float、Double等的引用變量,==是比較地址的,而equals是比較內(nèi)容的。

publicclass TestEquals {publicstaticvoid main(String[] args)

{ Integer n1 =newInteger(30);

Integer n2 =newInteger(30);

Integer n3 =newInteger(31);

System.out.println(n1 == n2);//結(jié)果是false 兩個(gè)不同的Integer對(duì)象,故其地址不同,System.out.println(n1 == n3);//那么不管是new Integer(30)還是new Integer(31) 結(jié)果都顯示falseSystem.out.println(n1.equals(n2));//結(jié)果是true 根據(jù)jdk文檔中的說明,n1與n2指向的對(duì)象中的內(nèi)容是相等的,都是30,故equals比較后結(jié)果是trueSystem.out.println(n1.equals(n3));//結(jié)果是false 因?qū)ο髢?nèi)容不一樣,一個(gè)是30一個(gè)是31}

}

這是Integer的實(shí)例,如果是其他的比如Double、Character、Float等也一樣。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容