java object 之clone方法全面解析
1 protected native Object clone() throws CloneNotSupportedException;
1、方法由native關(guān)鍵字修飾
java中的native關(guān)鍵字表示這個方法是個本地方法,【java native說明】。而且native修飾的方法執(zhí)行效率比非native修飾的高。
2、方法由protected修飾
一個類在覆蓋clone()方法時候,需要修改成public訪問修飾符,這樣才能保證其他所有的類都能夠訪問這個類的這個方法。
3、方法拋出CloneNotSupportedException異常
一個類想要覆蓋clone()方法,必須本身實(shí)現(xiàn)java.lang.Cloneable接口,否則會拋出CloneNotSupportedException異常。
二、clone()的作用
注:我們這里的對象特指復(fù)雜類型的。
1、簡單的=操作
我們知道,java中的復(fù)雜類型的對象都是引用類型,他們往往存的都是對象的內(nèi)存地址。因此我們不能僅僅通過 = 操作符這樣簡單的賦值操作。我們將一個對象a 賦值給另一個對象b ,我們僅僅是將對象a 的內(nèi)存地址賦值給b ,使得他們兩個對象都是指向的同一個內(nèi)存地址。這樣的后果是,對其中一個對象的修改之后都會影響到另一個對象。如下圖表示:
Person p1 = new Person(); Person p2 = p1;

2、clone()
使用clone()方法,可以快速的創(chuàng)建一個對象的副本,并且兩個對象指向不同的內(nèi)存地址。如下圖表示:
Person p1 = new Person(); Person p2 = p1.clone();

三、shallow clone和deep clone1、shallow clone(淺拷貝)
shallow clone是指只clone對象本身,不clone對象里的字段。只調(diào)用super.clone(),只是shallow clone。雖然拷貝之后的對象是指向了不同的內(nèi)存地址,但是對象里面的字段還是和之前的對象指向同一個內(nèi)存地址。
public class ShallowClone implements Cloneable {
public String name;
public int age;
public Person person;
public ShallowClone() {
}
public ShallowClone(String name, int age, Person person) {
this.name = name;
this.age = age;
this.person = person;
}
@Override
public ShallowClone clone() {
ShallowClone c = null;
try {
c = (ShallowClone) super.clone();
return c;
} catch (CloneNotSupportedException e) {
e.printStackTrace();
}
return c;
}
public static void main(String[] args) {
Person p = new Person();
p.name = "p";
p.age = 10;
ShallowClone c1 = new ShallowClone("Jim", 18, p);
System.out.printf("before clone: c1 = %s, c1.person = %s\n", c1, c1.person);
ShallowClone c2 = c1.clone();
System.out.printf("after clone: c2 = %s, c2.person = %s\n", c2, c2.person);
}
}
運(yùn)行main()輸出:
before clone: c1 = cre.sample.test.object.ShallowClone@558385e3, c1.person = cre.sample.test.Person@2dcb25f1 after clone: c2 = cre.sample.test.object.ShallowClone@742808b3, c2.person = cre.sample.test.Person@2dcb25f1
說明淺拷貝,ShallowClone對象內(nèi)存地址改變了,但是對象里的Person字段內(nèi)存地址沒有改變;
2、deep clone(深拷貝)
deep clone則是指在clone對象本身的同時,也clone對象里面的字段。
/**
* deep clone代碼示例
* Created by CreGu on 2016/6/9.
*/
public class DeepClone implements Cloneable {
public String name;
public int age;
public Person person;
public DeepClone() {
}
public DeepClone(String name, int age, Person person) {
this.name = name;
this.age = age;
this.person = person;
}
@Override
public DeepClone clone() {
DeepClone c = null;
try {
c = (DeepClone) super.clone();
c.person = person.clone();
return c;
} catch (CloneNotSupportedException e) {
e.printStackTrace();
}
return c;
}
public static void main(String[] args) {
Person p = new Person();
p.name = "p";
p.age = 10;
DeepClone c1 = new DeepClone("Jim", 18, p);
System.out.printf("before clone: c1 = %s, c1.person = %s\n", c1, c1.person);
DeepClone c2 = c1.clone();
System.out.printf("after clone: c2 = %s, c2.person = %s\n", c2, c2.person);
}
}
運(yùn)行main()輸出:
before clone: c1 = cre.sample.test.object.DeepClone@558385e3, c1.person = cre.sample.test.Person@2dcb25f1 after clone: c2 = cre.sample.test.object.DeepClone@742808b3, c2.person = cre.sample.test.Person@70535b58
說明深拷貝,DeepClone對象內(nèi)存地址改變了,但是對象里的Person字段內(nèi)存地址也改變了。
以上這篇java object 之clone方法全面解析就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Runtime.getRuntime().exec 路徑包含空格的解決
這篇文章主要介紹了Runtime.getRuntime().exec 路徑包含空格的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-11-11
Java 運(yùn)算符 動力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要介紹了Java 運(yùn)算符 動力節(jié)點(diǎn)Java學(xué)院整理,需要的朋友可以參考下2017-04-04
基于斷點(diǎn)續(xù)傳下載原理的實(shí)現(xiàn)
下面小編就為大家?guī)硪黄跀帱c(diǎn)續(xù)傳下載原理的實(shí)現(xiàn)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-09-09
SpringCloud中的openFeign調(diào)用服務(wù)并傳參的過程
服務(wù)和服務(wù)之間通信,不僅僅是調(diào)用,往往在調(diào)用過程中還伴隨著參數(shù)傳遞,接下來重點(diǎn)來看看OpenFeign在調(diào)用服務(wù)時如何傳遞參數(shù),感興趣的朋友一起看看吧2023-11-11

