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

Object.MemberwiseClone 메서드

업데이트: 2010년 10월

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

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

[SecuritySafeCriticalAttribute]
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이 수행하는 shallow copy 작업이 당신의 필요에 맞지 않는 경우, deep copy 작업을 구현하는 여러 가지 방법이 있습니다. 그 방법들은 다음과 같습니다.

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

  • 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 Demo(System.Windows.Controls.TextBlock outputBlock)
   {
      // 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
      outputBlock.Text += "Original values of p1 and p2:" + "\n";
      outputBlock.Text += "   p1 instance values: " + "\n";
      DisplayValues(outputBlock, p1);
      outputBlock.Text += "   p2 instance values:" + "\n";
      DisplayValues(outputBlock, 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;
      outputBlock.Text += "\nValues of p1 and p2 after changes to p1:" + "\n";
      outputBlock.Text += "   p1 instance values: " + "\n";
      DisplayValues(outputBlock, p1);
      outputBlock.Text += "   p2 instance values:" + "\n";
      DisplayValues(outputBlock, 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;
      outputBlock.Text += "\nValues of p1 and p3 after changes to p1:" + "\n";
      outputBlock.Text += "   p1 instance values: " + "\n";
      DisplayValues(outputBlock, p1);
      outputBlock.Text += "   p3 instance values:" + "\n";
      DisplayValues(outputBlock, p3);
   }

   public static void DisplayValues(System.Windows.Controls.TextBlock outputBlock, Person p)
   {
      outputBlock.Text += String.Format("      Name: {0:s}, Age: {1:d}", p.Name, p.Age) + "\n";
      outputBlock.Text += String.Format("      Value: {0:d}", p.IdInfo.IdNumber) + "\n";
   }
}
// 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.IdInfo 속성을 포함하여 복제된 Person 개체는 원본 개체에 영향을 주지 않고 수정할 수 있습니다.

Silverlight

5, 4, 3에서 지원

Windows Phone용 Silverlight

Windows Phone OS 7.1, Windows Phone OS 7.0에서 지원

XNA Framework

Xbox 360, Windows Phone OS 7.0에서 지원

Silverlight에서 지원되는 운영 체제 및 브라우저에 대한 자세한 내용은 지원되는 운영 체제 및 브라우저을 참조하십시오.

날짜

기록

이유

2010년 10월

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

고객 의견

커뮤니티 추가 항목

추가
표시: