亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

簡(jiǎn)單介紹java中equals以及==的用法

 更新時(shí)間:2021年01月14日 11:00:53   作者:韋邦杠  
這篇文章主要介紹了簡(jiǎn)單介紹java中equals以及==的用法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

簡(jiǎn)單介紹

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

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

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

1、“==”比較兩個(gè)變量本身的值,即兩個(gè)對(duì)象在內(nèi)存中的首地址。(java中,對(duì)象的首地址是它在內(nèi)存中存放的起始地址,它后面的地址是用來(lái)存放它所包含的各個(gè)屬性的地址,所以?xún)?nèi)存中會(huì)用多個(gè)內(nèi)存塊來(lái)存放對(duì)象的各個(gè)參數(shù),而通過(guò)這個(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)存地址不一樣,也就是說(shuō)它們指向的對(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
 

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

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

注意:

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

對(duì)于非字符串變量來(lái)說(shuō),"=="和"equals"方法的作用是相同的都是用來(lái)比較其,對(duì)象在堆內(nèi)存的首地址,即用來(lá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ì)于字符串來(lái)說(shuō)是比較內(nèi)容的,而對(duì)于非字符串來(lái)說(shuō)是比較,其指向的對(duì)象是否相同的。

2、 == 比較符也是比較指向的對(duì)象是否相同的也就是對(duì)象在對(duì)內(nèi)存中的的首地址。String類(lèi)中重新定義了equals這個(gè)方法,而且比較的是值,而不是地址。所以是true。

關(guān)于equals與==的區(qū)別從以下幾個(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);//結(jié)果是false 
System.out.println(a == c);//結(jié)果是true 
System.out.println(a.equals(c));//錯(cuò)誤,編譯不能通過(guò),equals方法 
//不能運(yùn)用與基本類(lèi)型的比較 
} 
}

(2) 對(duì)于基本類(lèi)型的包裝類(lèi)型,比如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文檔中的說(shuō)明,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è)類(lèi)作進(jìn)一步的說(shuō)明。

(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é)果疑問(wèn):乍一看結(jié)果,有點(diǎn)驚訝,為什么不是true呢,不是說(shuō)equals方法是比較內(nèi)容的嗎?

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

總結(jié): 

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

到此這篇關(guān)于簡(jiǎn)單介紹java中equals以及==的用法的文章就介紹到這了,更多相關(guān)java中equals以及==內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 深入探究Spring底層核心原理

    深入探究Spring底層核心原理

    理解IOC與AOP的實(shí)現(xiàn)機(jī)制,優(yōu)化應(yīng)用性能與可維護(hù)性。Spring通過(guò)IOC容器管理Bean,AOP實(shí)現(xiàn)切面編程,支持事務(wù)管理、ORM框架等。深入理解Spring原理,可以幫助我們更好地使用Spring框架,提高開(kāi)發(fā)效率與質(zhì)量
    2023-04-04
  • springboot 通過(guò)代碼自動(dòng)生成pid的方法

    springboot 通過(guò)代碼自動(dòng)生成pid的方法

    這篇文章主要介紹了springboot 通過(guò)代碼自動(dòng)生成pid的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-07-07
  • 關(guān)于SpringBoot使用@ExceptionHandler注解局部異常處理

    關(guān)于SpringBoot使用@ExceptionHandler注解局部異常處理

    這篇文章主要介紹了關(guān)于SpringBoot使用@ExceptionHandler注解局部異常處理,SpringBoot提供了多種方式來(lái)處理異常,在本文中,我們將介紹SpringBoot中的@ExceptionHandler注解,演示如何使用它進(jìn)行局部異常處理
    2023-07-07
  • SpringBoot整合logback日志的詳細(xì)步驟

    SpringBoot整合logback日志的詳細(xì)步驟

    這篇文章主要介紹了SpringBoot整合logback日志的詳細(xì)步驟,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-05-05
  • Mybatis 將table表名作為參數(shù)傳入操作

    Mybatis 將table表名作為參數(shù)傳入操作

    這篇文章主要介紹了Mybatis 將table表名作為參數(shù)傳入操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-12-12
  • Java遍歷Map的5種方式實(shí)例

    Java遍歷Map的5種方式實(shí)例

    Map作為Java中的一種集合,以鍵值對(duì)的形式存放一批數(shù)據(jù),經(jīng)常會(huì)被我們應(yīng)用在項(xiàng)目中,下面這篇文章主要給大家介紹了關(guān)于Java遍歷Map的5種方式,需要的朋友可以參考下
    2023-02-02
  • 探索Java中private方法添加@Transactional事務(wù)未生效原因

    探索Java中private方法添加@Transactional事務(wù)未生效原因

    你又遇到過(guò)明明給private方法添加了@Transactional但是事務(wù)依然沒(méi)有生效的情況嗎,具體原因本篇文章將詳細(xì)告訴你,有需要的朋友跟著小編往下看吧
    2021-11-11
  • 使用SpringBoot內(nèi)置web服務(wù)器

    使用SpringBoot內(nèi)置web服務(wù)器

    這篇文章主要介紹了使用SpringBoot內(nèi)置web服務(wù)器操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • Spring MVC 啟動(dòng)過(guò)程源碼分析詳解

    Spring MVC 啟動(dòng)過(guò)程源碼分析詳解

    這篇文章主要介紹了Spring MVC 啟動(dòng)過(guò)程源碼分析詳解,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-07-07
  • 利用keytools為tomcat 7配置ssl雙向認(rèn)證的方法

    利用keytools為tomcat 7配置ssl雙向認(rèn)證的方法

    雙向認(rèn)證和單向認(rèn)證原理基本差不多,只是除了客戶端需要認(rèn)證服務(wù)端以外,增加了服務(wù)端對(duì)客戶端的認(rèn)證,下面這篇文章主要介紹了利用keytools為tomcat 7配置ssl雙向認(rèn)證的方法,需要的朋友可以借鑒,下面來(lái)一起看看吧。
    2017-02-02

最新評(píng)論