Salinan Dalam vs. Cetek dalam Pengaturcaraan
Penyalinan cetek melibatkan penciptaan objek baharu yang merujuk data asas yang sama seperti yang asal. Sebaliknya, penyalinan dalam membina objek baharu yang mengandungi pendua bebas semua data yang dikaitkan dengan yang asal.
Pertimbangkan kelas C berikut:
<code class="c++">class X { public: int i; int *pi; X() : pi(new int) {} X(const X& copy) : i(copy.i), pi(copy.pi) {} };</code>
Dalam kes ini, penyalinan cetek akan terhasil dalam kedua-dua objek X asal dan salinan yang menunjuk ke objek int yang sama apabila memberikan pi:
<code class="c++">X original; X copy(original);</code>
Sebaliknya, penyalinan dalam termasuk langkah dalam pembina salinan di mana objek int baharu diperuntukkan:
<code class="c++">class X { public: int i; int *pi; X() : pi(new int) {} X(const X& copy) : i(copy.i), pi(new int(*copy.pi)) {} };</code>
Akibatnya, objek X yang disalin akan mempunyai objek int sendiri dengan nilai yang sama seperti yang asal.
Pada mulanya, pembina salinan lalai dianggap sentiasa melakukan salinan cetek. Walau bagaimanapun, telah dijelaskan bahawa tingkah laku bergantung kepada jenis setiap ahli. Piawaian menentukan penyalinan ahli, bermakna jenis skalar (seperti int dalam contoh ini) disalin menggunakan pengendali tugasan terbina dalam.
Oleh itu, pilihan antara penyalinan dalam dan cetek bergantung pada keperluan khusus aplikasi dan ciri-ciri data yang disalin.
Atas ialah kandungan terperinci Deep vs. Shallow Copy: Bilakah Anda Harus Memilih Yang Mana?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!