문서를 영문으로 보려면 영문 확인란을 선택하세요. 마우스 포인터를 텍스트 위로 이동시켜 팝업 창에서 영문 텍스트를 표시할 수도 있습니다.
번역
영문
이 설명서는 보관되지만 유지 되지 않습니다.

Object.MemberwiseClone 메서드

업데이트: 2010년 9월

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

네임스페이스:  System
어셈블리:  mscorlib(mscorlib.dll)

protected Object MemberwiseClone()

반환 값

형식: System.Object
Object 의 단순 복사본입니다.

MemberwiseClone 메서드는 새 개체를 만들고 현재 개체의 비정적 필드를 새 개체로 복사하여 단순 복사본을 만듭니다. 필드가 값 형식인 경우 필드의 비트별 복사가 수행됩니다. 필드가 참조 형식인 경우 참조는 복사되지만 참조되는 개체는 복사되지 않으므로 원본 개체와 복사된 개체는 동일한 개체를 참조합니다.

예를 들어, A와 B 개체를 참조하는 X라는 개체를 고려해야 합니다. 개체 B는 차례로 개체 C를 참조합니다. X를 단순 복사하면 A와 B 개체를 참조하는 새 개체 X2가 생성됩니다. 반면에 X의 전체 복사가 A와 B의 복사본인 새 개체 A2와 B2를 참조하는 새 개체 X2를 만듭니다. 이제 B2는 C의 복사본인 새 개체 C2를 참조합니다. 이 예제에서는 단순 복사와 전체 복사 작업 사이의 차이점을 보여줍니다.

MemberwiseClone 메서드에서 수행한 단순 복사 작업이 사용자 요구를 충족하지 않는 경우 전체 복사 작업을 구현하는 방법은 여러 가지가 있습니다. 이러한 요구 사항은 다음과 같습니다.

  • 복사할 개체의 클래스 생성자를 호출하여 첫 번째 개체에서 가져온 속성 값으로 두 번째 개체를 만듭니다. 이 경우 개체의 값이 클래스 생성자에 의해 완전히 정의되었다고 가정합니다.

  • MemberwiseClone 메서드를 호출하여 개체를 단순 복사한 다음, 원본 개체와 값이 같은 새 개체를 값이 참조 유형인 임의의 속성 또는 필드에 할당합니다. 예제의 DeepCopy 메서드는 이 방법을 보여 줍니다.

  • 전체 복사할 개체를 serialize한 다음 serialize된 데이터를 다른 개체 변수로 복원합니다.

  • 재귀가 있는 리플렉션을 사용하여 전체 복사 작업을 수행합니다.

다음 예제에서는 MemberwiseClone 메서드를 사용하는 방법을 보여 줍니다. MemberwiseClone 메서드를 호출하는 ShallowCopy 메서드를 정의하여 Person 개체에 단순 복사 작업을 수행합니다. 또한 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)this.MemberwiseClone();
    }

    public Person DeepCopy()
    {
       Person other = (Person) this.MemberwiseClone(); 
       other.IdInfo = new IdInfo(this.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 Person();
        p1.Age = 42;
        p1.Name = "Sam";
        p1.IdInfo = new IdInfo(6565);

        // Perform a shallow copy of p1 and assign it to p2.
        Person p2 = (Person) 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.Name = "George";
        p1.Age = 39;
        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: {0:s}, Age: {1:d}", p.Name, p.Age);
        Console.WriteLine("      Value: {0:d}", p.IdInfo.IdNumber);
    }
}
// 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 개체를 반환합니다. 예제의 출력과 같이, MemberwiseClone 메서드를 호출하여 Person 개체를 복제한 경우 복제된 Person 개체는 동일한 Person.IdInfo 개체 참조를 공유하는 것을 제외하고 원본 개체로부터 독립적인 복사본입니다. 결과적으로, 클론의 Person.IdInfo 속성을 수정하면 원래 개체의 Person.IdInfo 속성이 변경됩니다. 반대로, 전체 복사 작업을 수행할 경우 Person.IdInfo 속성을 포함하여 복제된 Person 개체는 원본 개체에 영향을 미치지 않고 수정할 수 있습니다.

.NET Framework

4, 3.5, 3.0, 2.0, 1.1, 1.0에서 지원

.NET Framework Client Profile

4, 3.5 SP1에서 지원

에서 지원

Windows 7, Windows Vista SP1 이상, Windows XP SP3, Windows XP SP2 x64 버전, Windows Server 2008(Server Core는 지원되지 않음), Windows Server 2008 R2(Server Core는 SP1 이상에서 지원됨), Windows Server 2003 SP2

.NET Framework에서 모든 플랫폼의 전체 버전을 지원하지는 않습니다. 지원되는 버전의 목록을 보려면 .NET Framework 시스템 요구 사항을 참조하십시오.

날짜

변경 내용

이유

2010년 9월

비고 섹션을 수정하고 예제를 교체했습니다.

고객 의견

표시: