兩個物件要進行比較之前,我們首先需要確定依據什麼來進行比較,物件中的成員變數那麼多,直接比較是無法比較的
此介面裡面只有一個compareTo抽象方法,結構如下:
在類別中實作此介面後就可以進行類別和類別之間的大小的比較
這個介面中有一個抽象方法compare,同樣是用來實作物件之間比較大小,方法的結構如下:
#和Comparable< ;T>介面不同的是,Comparator
如果是元素為類別的數組,使用Comparator 這個介面是空接口,但類別需要實作此介面才能被克隆,而要重寫的方法則是Object類別中的clone()方法 在IDEA中自動重寫的clone()方法如下: throws以及後面的語句不是現在的重點,暫時略過 因為此方法的回傳值是Object類,所以在使用的時候記得結果強制型別轉換成子類 既然說到克隆,那就不得不提深拷貝和淺拷貝,簡單說下二者的概念: 假設將A的內容拷貝到B中,然後我們修改B中的內容,如果A的內容沒有改變,那麼就是深拷貝,否則就是淺拷貝 #需要說明的是:一個克隆方法是深拷貝還是淺拷貝和類裡面的成員變量以及自己寫的程式碼都有關係,兩個不同的類別使用同一個克隆方法,一個是深拷貝,另一個是淺拷貝,這種情況是存在的 現在有一個類別如下: 我們在main方法中將其實例化後克隆給另一個對象,看看結果: 此時a並沒有因為b的改變而改變,clone()為深拷貝 我們再將類別A進行改造: 結果如下:2.複製物件
2.1 Cloneable
2.2 深拷貝和淺拷貝
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 +
'}';
}
}
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 +
'}';
}
}
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 +
'}';
}
}
public boolean equals(Object obj) { return (this == obj); }關於“ ==”,如果兩邊的變數是基本型別的變量,比較的是值是否相同,而如果是引用型別的變數的話,比較的則是位址是否相同
##3.2 toString
以上是Java抽象類別與介面怎麼定義使用的詳細內容。更多資訊請關注PHP中文網其他相關文章!