Baca dalam bahasa Inggris

Bagikan melalui


Object.MemberwiseClone Metode

Definisi

Membuat salinan dangkal dari Objectsaat ini.

C#
protected object MemberwiseClone();

Mengembalikan

Salinan dangkal dari Objectsaat ini .

Contoh

Contoh berikut mengilustrasikan metode MemberwiseClone. Ini mendefinisikan metode ShallowCopy yang memanggil metode MemberwiseClone untuk melakukan operasi penyalinan dangkal pada objek Person. Ini juga mendefinisikan metode DeepCopy yang melakukan operasi salinan mendalam pada objek Person.

C#
using System;

public class IdInfo
{
    public int IdNumber;

    public IdInfo(int IdNumber)
    {
        this.IdNumber = IdNumber;
    }
}

public class Person
{
    public int Age;
    public string Name;
    public IdInfo IdInfo;

    public Person ShallowCopy()
    {
        return (Person)MemberwiseClone();
    }

    public Person DeepCopy()
    {
        Person other = (Person)MemberwiseClone();
        other.IdInfo = new IdInfo(IdInfo.IdNumber);
        return other;
    }
}

public class Example
{
    public static void Main()
    {
        // Create an instance of Person and assign values to its fields.
        Person p1 = new()
        {
            Age = 42,
            Name = "Sam",
            IdInfo = new IdInfo(6565)
        };

        // Perform a shallow copy of p1 and assign it to p2.
        Person p2 = p1.ShallowCopy();

        // Display values of p1, p2
        Console.WriteLine("Original values of p1 and p2:");
        Console.WriteLine("   p1 instance values: ");
        DisplayValues(p1);
        Console.WriteLine("   p2 instance values:");
        DisplayValues(p2);

        // Change the value of p1 properties and display the values of p1 and p2.
        p1.Age = 32;
        p1.Name = "Frank";
        p1.IdInfo.IdNumber = 7878;
        Console.WriteLine("\nValues of p1 and p2 after changes to p1:");
        Console.WriteLine("   p1 instance values: ");
        DisplayValues(p1);
        Console.WriteLine("   p2 instance values:");
        DisplayValues(p2);

        // Make a deep copy of p1 and assign it to p3.
        Person p3 = p1.DeepCopy();
        // Change the members of the p1 class to new values to show the deep copy.
        p1.Age = 39;
        p1.Name = "George";
        p1.IdInfo.IdNumber = 8641;
        Console.WriteLine("\nValues of p1 and p3 after changes to p1:");
        Console.WriteLine("   p1 instance values: ");
        DisplayValues(p1);
        Console.WriteLine("   p3 instance values:");
        DisplayValues(p3);
    }

    public static void DisplayValues(Person p)
    {
        Console.WriteLine($"      Name: {p.Name:s}, Age: {p.Age:d}");
        Console.WriteLine($"      Value: {p.IdInfo.IdNumber:d}");
    }
}

/* The example displays the following output:
 * 
 * Original values of p1 and p2:
      p1 instance values:
         Name: Sam, Age: 42
         Value: 6565
      p2 instance values:
         Name: Sam, Age: 42
         Value: 6565

   Values of p1 and p2 after changes to p1:
      p1 instance values:
         Name: Frank, Age: 32
         Value: 7878
      p2 instance values:
         Name: Sam, Age: 42
         Value: 7878

   Values of p1 and p3 after changes to p1:
      p1 instance values:
         Name: George, Age: 39
         Value: 8641
      p3 instance values:
         Name: Frank, Age: 32
         Value: 7878
 */

Dalam contoh ini, properti Person.IdInfo mengembalikan objek IdInfo. Seperti yang ditunjukkan oleh output dari contoh, ketika objek Person dikloning dengan memanggil metode MemberwiseClone, objek Person yang dikloning adalah salinan independen dari objek asli, kecuali bahwa mereka berbagi referensi objek Person.IdInfo yang sama. Akibatnya, memodifikasi properti Person.IdInfo kloning mengubah properti Person.IdInfo objek asli. Di sisi lain, ketika operasi penyalinan mendalam dilakukan, objek Person kloning, termasuk properti Person.IdInfo, dapat dimodifikasi tanpa memengaruhi objek asli.

Keterangan

Metode MemberwiseClone membuat salinan dangkal dengan membuat objek baru, lalu menyalin bidang nonstatis objek saat ini ke objek baru. Jika bidang adalah jenis nilai, salinan bit-by-bit bidang dilakukan. Jika bidang adalah jenis referensi, referensi disalin tetapi objek yang dirujuk tidak; oleh karena itu, objek asli dan kloningnya merujuk ke objek yang sama.

Untuk mengilustrasikan perbedaan antara operasi penyalinan dangkal dan mendalam, pertimbangkan objek yang disebut X yang mereferensikan objek A dan B. Objek B, pada gilirannya, mereferensikan objek C. Salinan X dangkal membuat objek baru X2 yang juga mereferensikan objek A dan B. Sebaliknya, salinan mendalam X membuat objek baru X2 yang mereferensikan objek baru A2 dan B2, yang merupakan salinan A dan B. B2, pada gilirannya, mereferensikan objek baru C2, yang merupakan salinan C.

Ada banyak cara untuk menerapkan operasi salinan mendalam jika operasi penyalinan dangkal yang dilakukan oleh metode MemberwiseClone tidak memenuhi kebutuhan Anda. Ini termasuk yang berikut ini:

  • Panggil konstruktor kelas objek yang akan disalin untuk membuat objek kedua dengan nilai properti yang diambil dari objek pertama. Ini mengasumsikan bahwa nilai objek sepenuhnya ditentukan oleh konstruktor kelasnya.
  • Panggil metode MemberwiseClone untuk membuat salinan objek dangkal, lalu tetapkan objek baru yang nilainya sama dengan objek asli ke properti atau bidang apa pun yang nilainya adalah jenis referensi. Metode DeepCopy dalam contoh mengilustrasikan pendekatan ini.
  • Serialisasi objek yang akan disalin secara mendalam, lalu pulihkan data berseri ke variabel objek yang berbeda.
  • Gunakan refleksi dengan rekursi untuk melakukan operasi penyalinan mendalam.

Berlaku untuk

Produk Versi
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9, 10
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0