簡(jiǎn)單介紹java中equals以及==的用法
簡(jiǎn)單介紹
equals方法是java.lang.Object類的方法有兩種用法說明:
一、對(duì)于字符串變量來說,使用“==”和“equals()”方法比較字符串時(shí),其比較方法不同。
1、“==”比較兩個(gè)變量本身的值,即兩個(gè)對(duì)象在內(nèi)存中的首地址。(java中,對(duì)象的首地址是它在內(nèi)存中存放的起始地址,它后面的地址是用來存放它所包含的各個(gè)屬性的地址,所以內(nèi)存中會(huì)用多個(gè)內(nèi)存塊來存放對(duì)象的各個(gè)參數(shù),而通過這個(gè)首地址就可以找到該對(duì)象,進(jìn)而可以找到該對(duì)象的各個(gè)屬性)
2、“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,故相等。
String s1,s2,s3 = 'abc', s4 ='abc' ; s1 = new String('abc'); s2 = new String('abc'); System.out.println('s1==s2:'+(s1==s2)); System.out.println('s1==s3:'+(s1==s3)); System.out.println('s3==s4:'+(s3==s4)); System.out.println('s1.equals(s2):'+(s1.equals(s2))); System.out.println('s1.equals(s3):'+(s1.equals(s3))); System.out.println('s3.equals(s4):'+(s3.equals(s4)));
測(cè)試圖
注意:
StringBuffer s1 = new StringBuffer('a'); StringBuffer s2 = new StringBuffer('a'); System.out.println('s1.equals(s2):'+(s1.equals(s2)));//結(jié)果為false
解釋:StringBuffer類中沒有重新定義equals這個(gè)方法,因此這個(gè)方法就來自O(shè)bject類,(Object類中的equals方法是用來比較“地址”的,所以等于false)注意:對(duì)于s3和s4來說,有一點(diǎn)不一樣要引起注意,由于s3和s4是兩個(gè)字符,串常量所生成的變量,其中所存放的內(nèi)存地址是相等的,所以s3==s4是true(即使沒有s3=s4這樣一個(gè)賦值語句)對(duì)于非字符串變量來說,'=='和'equals'方法的作用是相同的都是用來比較其,對(duì)象在堆內(nèi)存的首地址,即用來比較兩個(gè)引用變量是否指向同一個(gè)對(duì)象。
比如:
class A{ A obj1 = new A(); A obj2 = new A();} obj1==obj2//結(jié)果為false obj1.equals(obj2)//是false //但是如加上這樣一句: obj1=obj2; //執(zhí)行后 obj1==obj2 //是true obj1.equals(obj2) //是true
1、equals方法對(duì)于字符串來說是比較內(nèi)容的,而對(duì)于非字符串來說是比較,其指向的對(duì)象是否相同的。
2、 == 比較符也是比較指向的對(duì)象是否相同的也就是對(duì)象在對(duì)內(nèi)存中的的首地址。String類中重新定義了equals這個(gè)方法,而且比較的是值,而不是地址。所以是true。
關(guān)于equals與==的區(qū)別從以下幾個(gè)方面來說:
(1) 如果是基本類型比較,那么只能用==來比較,不能用equals比如:
public class TestEquals { public static void main(String[] args) { int a = 3; int b = 4; int c = 3; System.out.println(a == b);//結(jié)果是false System.out.println(a == c);//結(jié)果是true System.out.println(a.equals(c));//錯(cuò)誤,編譯不能通過,equals方法 //不能運(yùn)用與基本類型的比較 } }
(2) 對(duì)于基本類型的包裝類型,比如Boolean、Character、Byte、Shot、Integer、Long、Float、Double等的引用變量,==是比較地址的,而equals是比較內(nèi)容的。比如
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);//結(jié)果是false 兩個(gè)不同的Integer對(duì)象,故其地址不同, System.out.println(n1 == n3);//那么不管是new Integer(30)還是new Integer(31) 結(jié)果都顯示false System.out.println(n1.equals(n2));//結(jié)果是true 根據(jù)jdk文檔中的說明,n1與n2指向的對(duì)象中的內(nèi)容是相等的,都是30,故equals比較后結(jié)果是true System.out.println(n1.equals(n3));//結(jié)果是false 因?qū)ο髢?nèi)容不一樣,一個(gè)是30一個(gè)是31 } }
這是Integer的實(shí)例,如果是其他的比如Double、Character、Float等也一樣
(3) 注意:對(duì)于String(字符串)、StringBuffer(線程安全的可變字符序列)、StringBuilder(可變字符序列)這三個(gè)類作進(jìn)一步的說明。
(4)該例子是Java編程思想第三章的例子:
class Value { int i; } public class EqualsMethod2 { public static void main(String[] args) { Value v1 = new Value(); Value v2 = new Value(); v1.i = v2.i = 100; System.out.println(v1.equals(v2));//(1)flase System.out.println(v1 == v2);//(2)true } }
運(yùn)行結(jié)果疑問:乍一看結(jié)果,有點(diǎn)驚訝,為什么不是true呢,不是說equals方法是比較內(nèi)容的嗎?
解釋:不錯(cuò),如果在新類中被覆蓋了equals方法,就可以用來比較內(nèi)容的。但是在上面的例子中類Value并沒有覆蓋Object中的equals方法,而是繼承了該方法,因此它就是被用來比較地址的,又v1和v2的所指向的對(duì)象不相同,故標(biāo)記(1)處的v1.equals(v2)運(yùn)行結(jié)果為false,標(biāo)記為(2)處的v1 == v2運(yùn)行結(jié)果也為false。
總結(jié):
如果是基本類型比較,那么只能用==來比較,不能用equals ,如果是基本類型的包裝類型,那么用equals
到此這篇關(guān)于簡(jiǎn)單介紹java中equals以及==的用法的文章就介紹到這了,更多相關(guān)java中equals以及==的用法內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. 解決docker與vmware的沖突問題2. Django中的AutoField字段使用3. Python基于jieba, wordcloud庫生成中文詞云4. IntelliJ Idea 2020.1 正式發(fā)布,官方支持中文(必看)5. IntelliJ IDEA設(shè)置自動(dòng)提示功能快捷鍵的方法6. asp.net core應(yīng)用docke部署到centos7的全過程7. Java 3D的動(dòng)畫展示(Part1-使用JMF)8. Django ORM實(shí)現(xiàn)按天獲取數(shù)據(jù)去重求和例子9. Android 實(shí)現(xiàn)徹底退出自己APP 并殺掉所有相關(guān)的進(jìn)程10. 刪除docker里建立容器的操作方法
