本文目錄一覽:
- 1、JAVA 中淺拷貝與深拷貝有什麼區別?
- 2、什麼是深拷貝和淺拷貝
- 3、java深拷貝和淺拷貝的區別
- 4、誰能給出一個java中深拷貝 的例子 啊,我不知道是啥東西,最好能解釋下深拷貝含義.
- 5、java中什麼是深拷貝,什麼是淺拷貝?
- 6、JAVA如何實現深拷貝
JAVA 中淺拷貝與深拷貝有什麼區別?
淺拷貝 指的是你的類本身被拷貝,而沒有拷貝類本身屬性中的類
深拷貝 指的是包含類本身和屬性類在內的所有類的拷貝。
簡單點說:
就是淺拷貝的兩個對象中的屬性還會指向同一個類,而深拷貝則全部單獨了。也就是說深拷貝把關聯關係也拷貝了。
具體例子你可以參看我的blog,裏面篇文章介紹:)
什麼是深拷貝和淺拷貝
淺拷貝就是指對象複製的時候只複製一層;深拷貝是指複製對象的所有層級。
深拷貝和淺拷貝,主要是對象發生複製的時候,根據複製的層級不同來區分的。很多人在這裡經常變量賦值發生混淆。對於JavaScript數組等複雜的數據類型來說,將其賦值給其它變量,其實只是複製了對象的地址給它,兩個變量指向的是同一個對象,因此普通的賦值既不是深拷貝也不是淺拷貝。
深拷貝和淺拷貝需要注意的地方就是可變元素的拷貝:
在淺拷貝時,拷貝出來的新對象的地址和原對象是不一樣的,但是新對象裏面的可變元素(如列表)的地址和原對象里的可變元素的地址是相同的,也就是說淺拷貝它拷貝的是淺層次的數據結構(不可變元素),對象里的可變元素作為深層次的數據結構並沒有被拷貝到新地址裏面去。
而是和原對象里的可變元素指向同一個地址,所以在新對象或原對象里對這個可變元素做修改時,兩個對象是同時改變的,但是深拷貝不會這樣,這個是淺拷貝相對於深拷貝最根本的區別。
java深拷貝和淺拷貝的區別
淺拷貝:只複製一個對象,對象內部存在的指向其他對象數組或者引用則不複製
深拷貝:對象,對象內部的引用均複製
示例:
public static Object copy(Object oldObj) {
Object obj = null;
try {
// Write the object out to a byte array
ByteArrayOutputStream bos = new ByteArrayOutputStream();
ObjectOutputStream out = new ObjectOutputStream(bos);
out.writeObject(oldObj);
out.flush();
out.close();
// Retrieve an input stream from the byte array and read
// a copy of the object back in.
ByteArrayInputStream bis = new ByteArrayInputStream(bos.toByteArray());
ObjectInputStream in = new ObjectInputStream(bis);
obj = in.readObject();
} catch (IOException e) {
e.printStackTrace();
} catch (ClassNotFoundException cnfe) {
cnfe.printStackTrace();
}
return obj;
}
誰能給出一個java中深拷貝 的例子 啊,我不知道是啥東西,最好能解釋下深拷貝含義.
舉個最簡單的例子:
class A {
public int i;
public int j;
}
A a = new A();
淺拷貝:
A a1 = a;
深拷貝:
A a1 = new A();
a1.i = a.i;
a1.j = a.j;
感覺如下:
淺拷貝只拷貝對象本身
深拷貝則拷貝對象中引用的對象,一直拷貝下去。
java中什麼是深拷貝,什麼是淺拷貝?
簡單點跟你說吧,容易理解。
淺拷貝:
就是複製對象的值的時候,不管複製多少,所以的值都指向同一個對象。
深拷貝:
在複製對象的值的時候,同時也重新創建了一個對象,每個值都指向一個不同的對象。
如果你學習了c語言的指針,會理解的更深刻
JAVA如何實現深拷貝
下面給你簡單介紹protected 域(或方法)實現過程思路:
protected 域(或方法)對本包內的所有類可見(當然包括子類),那麼,子類可以獲得訪超類受保護域(或方法)的權利,但是,若子類和超類不在同一個包下,就不能訪問超類對象的這個受保護域(或方法)。
淺拷貝與深拷貝
Object類對自己的具體子類的域一無所知,Object類的clone方法只是將各個域進行拷貝。數值或基本類型不會出現問題,但是,如果在對象中包含了引用對象,這些對象的內容沒有被自我複製,拷貝的結果也即是原始對象和拷貝對象引用着同一個引用對象(一般地,動詞「引用」可理解為「管理」,就是指向同一內存)。
淺拷貝滿足:
x.clone() != x為 true,
x.clone().getClass() == x.getClass()為true,
((x.clone().field1 ) == (x. field1)) … ((x.clone().fieldN )==(x. fieldN))也為 true 。
如果原始對象與淺拷貝對象共同引用(管理、指向)的引用對象是不可變的,將不會產生任何問題
如果原始對象管理的引用對象是可變的,就必須需重新定義clone方法,來實現深層次的拷貝。要對涉及的每一個類,判斷以下兩點:
默認的clone方法是否滿足需求。
默認的clone方法是否能通過調用可變引用對象的clone方法得到解決。
對涉及的每一個類,深拷貝要滿足:
x.clone() != x為 true,
x.clone().getClass() == x.getClass()為true,
x.clone().equals(x)也為 true ,當然equals方法是如此重寫過的。
Object類中的clone方法被聲明為protected,防止出現文章開頭所提到的,子類和超類不在同一個包下的情況,要聲明clone為public,來實現深拷貝
原創文章,作者:SECX,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/145708.html