欧美性猛交XXXX免费看蜜桃,成人网18免费韩国,亚洲国产成人精品区综合,欧美日韩一区二区三区高清不卡,亚洲综合一区二区精品久久

打開(kāi)APP
userphoto
未登錄

開(kāi)通VIP,暢享免費電子書(shū)等14項超值服

開(kāi)通VIP
java中equal和==的比較
 

java中equals方法和“==”的區別:

equals 方法是 java.lang.Object 類(lèi)的方法。

有兩種用法說(shuō)明:

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

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

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

比如:

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

s1 = new String("abc");

s2 = new String("abc");

那么:

s1==s2 是 false //兩個(gè)變量的內存地址不一樣,也就是說(shuō)它們指向的對象不 一樣,

故不相等。

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

注意(1):

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

StringBuffer s2 = new StringBuffer("a");

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

解釋?zhuān)篠tringBuffer類(lèi)中沒(méi)有重新定義equals這個(gè)方法,因此這個(gè)方法就來(lái)自Object類(lèi),

而Object類(lèi)中的equals方法是用來(lái)比較“地址”的,所以等于false.

注意(2):

對于s3和s4來(lái)說(shuō),有一點(diǎn)不一樣要引起注意,由于s3和s4是兩個(gè)字符

串常量所生成的變量,其中所存放的內存地址是相等的,

所以s3==s4是true(即使沒(méi)有s3=s4這樣一個(gè)賦值語(yǔ)句)

(2)對于非字符串變量來(lái)說(shuō),"=="和"equals"方法的作用是相同的都是用來(lái)比較其

對象在堆內存的首地址,即用來(lái)比較兩個(gè)引用變量是否指向同一個(gè)對象。

比如:

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方法對于字符串來(lái)說(shuō)是比較內容的,而對于非字符串來(lái)說(shuō)是比較

其指向的對象是否相同的。

== 比較符也是比較指向的對象是否相同的也就是對象在對內存中的的首地址。

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

關(guān)于equals與==的區別從以下幾個(gè)方面來(lái)說(shuō):

(1)如果是基本類(lèi)型比較,那么只能用==來(lái)比較,不能用equals

比如:

public class TestEquals {

public static void main(String[] args)

{

int a = 3;

int b = 4;

int c = 3;

System.out.println(a == b);//結果是false

System.out.println(a == c);//結果是true

System.out.println(a.equals(c));//錯誤,編譯不能通過(guò),equals方法

//不能運用與基本類(lèi)型的比較

}

}

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

public class TestEquals {

public static void main(String[] args)

{ Integer n1 = new Integer(30);

Integer n2 = new Integer(30);

Integer n3 = new Integer(31);

System.out.println(n1 == n2);//結果是false 兩個(gè)不同的Integer對象,故其地址不同,

System.out.println(n1 == n3);//那么不管是new Integer(30)還是new Integer(31) 結果都顯示false

System.out.println(n1.equals(n2));//結果是true 根據jdk文檔中的說(shuō)明,n1與n2指向的對象中的內容是相等的,都是30,故equals比較后結果是true

System.out.println(n1.equals(n3));//結果是false 因對象內容不一樣,一個(gè)是30一個(gè)是31

}

}

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

(3)注意:對于String(字符串)、StringBuffer(線(xiàn)程安全的可變字符序列)、StringBuilder(可變字符序列)這三個(gè)類(lèi)作進(jìn)一步的說(shuō)明。

(a)首先,介紹String的用法,請看下面的實(shí)例:

public class TestEquals {

public static void main(String[] args) {

String s1 = "123";

String s2 = "123";

String s3 = "abc";

String s4 = new String("123");

String s5 = new String("123");

String s6 = new String("abc");

System.out.println(s1 == s2);//(1)true

System.out.println(s1.equals(s2));//(2)true

System.out.println(s1 == s3);//(3)flase

System.out.println(s1.equals(s3));//(4)flase

System.out.println(s4 == s5);//(5)flase

System.out.println(s4.equals(s5));//(6)true

System.out.println(s4 == s6);//(7)flase

System.out.println(s4.equals(s6));//(8)flase

System.out.println(s1 == s4);//(9)false

System.out.println(s1.equals(s4));//(10)true

}

}

答案解釋?zhuān)簊1與s2分別指向由字符串常量”123” 創(chuàng )建的對象,在常量池中,只有一個(gè)對象,內容為123,有兩個(gè)引用s1和s2指向這個(gè)對象,故這兩個(gè)引用變量所指向的地址是相同的,因而(1)處的運行結果為true,又因為s1.equals(s2)是比較s1和s2所指向的對象的內容是否相等,而我們知道這兩個(gè)對象的內容都是字符串常量”123”,故標記(2)處的運行結果是true。

用同樣的方法分析,s1和s3所指向的對象不一樣,內容也不一樣,故標記(3)和(4)處運行結果是false。

再看看s4和s5,這兩個(gè)引用變量所指向的對象的內容都是一樣的(內容都是123),但是這兩個(gè)對象是用new操作符創(chuàng )建處類(lèi)的,是在內存中分配兩塊空間給這兩個(gè)對象的,因而這兩個(gè)對象的內存地址不一樣,故事兩個(gè)不同的對象,標記(5)處的s4 == s5 運行結果為false,但是內容一樣,故標記(6)處的s4.equals(s5)運行結果為true。同理,s4和s6所指向的對象地址不同,內容也不相同。故標記(7)(8)處運行結果為false。

s1和s4分別指向兩個(gè)不同的對象(之所以這樣稱(chēng)呼,是因為這兩個(gè)對象在內存中的地址不相同,故而對象不相同),故標記為(9)處的s1 == s4運行結果為false,而標記為(10)處的s1.equals(s4)運行結果疑問(wèn):乍一看結果,有點(diǎn)驚訝,為什么不是true呢,不是說(shuō)equals方法是比較內容的嗎?

解釋?zhuān)翰诲e,如果在新類(lèi)中被覆蓋了equals方法,就可以用來(lái)比較內容的。但是在上面的例子中類(lèi)Value并沒(méi)有覆蓋Object中的equals方法,而是繼承了該方法,因此它就是被用來(lái)比較地址的,又v1和v2的所指向的對象不相同,故標記(1)處的v1.equals(v2)運行結果為false,標記為(2)處的v1 == v2運行結果也為false。

本站僅提供存儲服務(wù),所有內容均由用戶(hù)發(fā)布,如發(fā)現有害或侵權內容,請點(diǎn)擊舉報。
打開(kāi)APP,閱讀全文并永久保存 查看更多類(lèi)似文章
猜你喜歡
類(lèi)似文章
==和equals
(2)eques(==)比較
java筆記.equals的方法
java中equals和equalsignorecase的區別
田哥:面試被問(wèn)== 與equals 的區別,該怎么回答?
Java中equals和==的區別
更多類(lèi)似文章 >>
生活服務(wù)
分享 收藏 導長(cháng)圖 關(guān)注 下載文章
綁定賬號成功
后續可登錄賬號暢享VIP特權!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服

欧美性猛交XXXX免费看蜜桃,成人网18免费韩国,亚洲国产成人精品区综合,欧美日韩一区二区三区高清不卡,亚洲综合一区二区精品久久