영어로 읽기

다음을 통해 공유


Object.MemberwiseClone 메서드

정의

현재 Object단순 복사본을 만듭니다.

protected object MemberwiseClone();

반환

현재 Object단순 복사본입니다.

예제

다음 예제에서는 MemberwiseClone 메서드를 보여 줍니다. MemberwiseClone 메서드를 호출하여 Person 개체에서 단순 복사 작업을 수행하는 ShallowCopy 메서드를 정의합니다. 또한 Person 개체에 대한 심층 복사 작업을 수행하는 DeepCopy 메서드를 정의합니다.

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
 */

이 예제에서 Person.IdInfo 속성은 IdInfo 개체를 반환합니다. 예제의 출력에서 알 수 있듯이 Person 개체가 MemberwiseClone 메서드를 호출하여 복제되는 경우 복제된 Person 개체는 동일한 Person.IdInfo 개체 참조를 공유한다는 점을 제외하고 원래 개체의 독립적인 복사본입니다. 결과적으로 복제본의 Person.IdInfo 속성을 수정하면 원래 개체의 Person.IdInfo 속성이 변경됩니다. 반면에 심층 복사 작업이 수행되면 원래 개체에 영향을 주지 않고 복제된 Person 개체(Person.IdInfo 속성 포함)를 수정할 수 있습니다.

설명

MemberwiseClone 메서드는 새 개체를 만든 다음 현재 개체의 비정적 필드를 새 개체에 복사하여 단순 복사본을 만듭니다. 필드가 값 형식인 경우 필드의 비트 단위 복사본이 수행됩니다. 필드가 참조 형식인 경우 참조가 복사되지만 참조된 개체는 복사되지 않습니다. 따라서 원래 개체와 해당 복제는 동일한 개체를 참조합니다.

단순 복사 작업과 딥 복사 작업의 차이점을 설명하기 위해 개체 A와 B를 참조하는 X라는 개체를 고려합니다. 개체 B는 개체 C를 참조합니다. X의 단순 복사본은 개체 A와 B도 참조하는 새 개체 X2를 만듭니다. 반면 X의 딥 복사본은 A와 B2의 복사본인 새 개체 A2 및 B2를 참조하는 새 개체 X2를 만듭니다. 그러면 C의 복사본인 새 개체 C2를 참조합니다.

MemberwiseClone 메서드에서 수행하는 단순 복사 작업이 요구 사항을 충족하지 않는 경우 딥 복사 작업을 구현하는 방법에는 여러 가지가 있습니다. 여기에는 다음이 포함되었습니다.

  • 복사할 개체의 클래스 생성자를 호출하여 첫 번째 개체에서 가져온 속성 값을 사용하여 두 번째 개체를 만듭니다. 이 경우 개체의 값이 클래스 생성자에 의해 완전히 정의된다고 가정합니다.
  • MemberwiseClone 메서드를 호출하여 개체의 단순 복사본을 만든 다음 값이 원래 개체와 동일한 새 개체를 참조 형식인 속성이나 필드에 할당합니다. 예제의 DeepCopy 메서드는 이 방법을 보여 줍니다.
  • 깊이 복사할 개체를 직렬화한 다음 직렬화된 데이터를 다른 개체 변수로 복원합니다.
  • 리플렉션과 재귀를 사용하여 딥 복사 작업을 수행합니다.

적용 대상

제품 버전
.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
.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