在Java中,拷貝對象是比較常見的操作。而拷貝對象有兩種方式:深拷貝和淺拷貝。深拷貝指的是將一個對象的所有屬性都復制到另一個對象中,而淺拷貝則只復制對象的引用。雖然深拷貝可以完全復制一個對象,但是由于復制了所有屬性,所以效率相對較慢,而淺拷貝則快得多。下面我們通過實驗來探討Java中深拷貝和淺拷貝的效率問題。
import java.util.ArrayList;
import java.util.List;
public class DeepCopyVSNormalCopy {
public static void main(String[] args) {
ListoriginList = new ArrayList<>();
for (int i = 0; i< 1000000; i++) {
originList.add(i);
}
// 淺拷貝
ListshallowCopyList = originList;
long start = System.currentTimeMillis();
for (int i = 0; i< originList.size(); i++) {
Integer integer = shallowCopyList.get(i);
}
System.out.println("shallow copy time:" + (System.currentTimeMillis() - start)); // shallow copy time:9
// 深拷貝
ListdeepCopyList = new ArrayList<>();
start = System.currentTimeMillis();
for (int i = 0; i< originList.size(); i++) {
Integer integer = originList.get(i);
deepCopyList.add(integer);
}
System.out.println("deep copy time:" + (System.currentTimeMillis() - start)); // deep copy time:890
}
}
以上代碼實現了淺拷貝和深拷貝的實驗,并采取了一個長度為1000000的list作為原始數據,從輸出結果可以看到:淺拷貝的時間只有9ms,而深拷貝卻需要890ms,可以看出,深拷貝的效率遠不如淺拷貝。
但是,在實際開發中,我們不能只因為效率問題就全部采用淺拷貝,因為淺拷貝并不能完全復制一個對象,當復制一個對象后,如果原對象的屬性發生變化,那么淺拷貝后的對象的屬性也會跟著變化,這可能會導致數據不一致的問題。所以,我們在使用拷貝對象的時候,需要結合實際情況斟酌選擇。
上一篇java深拷貝數組和對象
下一篇css中刪除線命令