Java由淺入深通關抽象類與接口下
本篇介紹在對對象進行比較和克隆操作的時候會使用的接口,然后介紹一個類:Object
在Java中Object類默認是所有類的父類,里面有一些常用的方法會介紹
1.對象的比較
兩個對象要進行比較之前,我們首先需要確定依據(jù)什么來進行比較,對象中的成員變量那么多,直接比較是無法比較的
1.1 Comparable<T>
<T>是接口的參數(shù),里面填要比較的對象的類型
此接口里面只有一個compareTo抽象方法,結構如下:
在類中實現(xiàn)此接口后就可以進行類和類之間的大小的比較
1.2 Comparator<T>
這個接口中有一個抽象方法compare,同樣是用來實現(xiàn)對象之間比較大小,方法的結構如下:
和Comparable<T>接口所不同的是,Comparator<T>接口可以作為Arrays類中sort方法的參數(shù)
如果是元素為類的數(shù)組,使用Comparator<T>接口可以進一步進行數(shù)組排序
2.克隆對象
2.1 Cloneable
這個接口是一個空接口,但類需要實現(xiàn)此接口才能被克隆,而要重寫的方法則是Object類中的clone()方法
在IDEA中自動重寫的clone()方法如下:
throws以及后面的語句不是現(xiàn)在的重點,暫時略過
因為此方法的返回值是Object類,所以在使用的時候記得結果強制類型轉換成子類
2.2 深拷貝和淺拷貝
既然說到克隆,那就不得不提深拷貝和淺拷貝,簡單說下二者的概念:
假設將A的內(nèi)容拷貝到B中,然后我們修改B中的內(nèi)容,如果A的內(nèi)容沒有改變,那么就是深拷貝,否則就是淺拷貝
需要說明的是:一個克隆方法是深拷貝還是淺拷貝和類里面的成員變量以及自己寫的代碼都有關系,兩個不同的類使用同一個克隆方法,一個是深拷貝,另一個是淺拷貝,這種情況是存在的
現(xiàn)在有一個類如下:
class A implements Cloneable{ int i; int j; @Override protected Object clone() throws CloneNotSupportedException { return super.clone(); } @Override public String toString() { return "{" + "i=" + i + ", j=" + j + '}'; } }
我們在main方法中將其實例化后克隆給另一個對象,看看結果:
此時a并沒有因為b的改變而改變,clone()為深拷貝
我們再將類A進行改造:
class B implements Cloneable { int k; } class A implements Cloneable{ int i; int j; B c=new B(); @Override protected Object clone() throws CloneNotSupportedException { return super.clone(); } @Override public String toString() { return "{" + "i=" + i + ", j=" + j + ", c.k=" + c.k + '}'; } }
結果如下:
那么此時clone是深拷貝還是淺拷貝?
出現(xiàn)這種結果的原因要從內(nèi)存上看,在類A沒有進行修改之前內(nèi)存如下:
類A修改后的內(nèi)存如下:
按照上圖來看,要實現(xiàn)深拷貝就需要把類B的內(nèi)容再克隆一份,所以我們需要對clone方法進行修改
class B implements Cloneable { int k; @Override protected Object clone() throws CloneNotSupportedException { return super.clone(); } } class A implements Cloneable{ int i; int j; B c=new B(); @Override protected Object clone() throws CloneNotSupportedException { A tmp=(A)super.clone(); tmp.c=(B)this.c.clone(); return tmp; } @Override public String toString() { return "{" + "i=" + i + ", j=" + j + ", c.k=" + c.k + '}'; } }
至于為什么自己畫圖試試 ,這里就不講了
3.Object類
Object類中有一些常用的方法這里拿出來介紹
3.1 equals
在Object類中此方法是用來比較大小的,返回值是布爾值,底層的實現(xiàn)邏輯如下:
public boolean equals(Object obj) { return (this == obj); }
關于“==”,如果兩邊的變量是基本類型的變量,比較的是值是否相同,而如果是引用類型的變量的話,比較的則是地址是否相同
3.2 toString
輸出語句System.out.println()底層調(diào)用的就是toString方法,不過如果輸出的是引用類型數(shù)據(jù)默認是輸出修改后的地址,所以此時需要對其進行重寫,這也是上面的例子中有toString方法的原因
本篇結束,完
到此這篇關于Java由淺入深通關抽象類與接口下的文章就介紹到這了,更多相關Java抽象類與接口內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
java調(diào)用chatgpt接口來實現(xiàn)專屬于自己的人工智能助手
這篇文章主要介紹了用java來調(diào)用chatget的接口,實現(xiàn)自己的聊天機器人,對人工智能感興趣的小伙伴可以參考閱讀2023-03-03