내보내기(0) 인쇄
모두 확장
정보
요청한 주제가 아래에 표시됩니다. 그러나 이 주제는 이 라이브러리에 포함되지 않습니다.

Object.MemberwiseClone 메서드

2013-12-13

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

Namespace:  System
어셈블리:  mscorlib(mscorlib.dll)

protected Object MemberwiseClone()

반환 값

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

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

예를 들어 개체 A와 개체 B를 참조하는 X라는 개체가 있다고 가정합니다. 개체 B는 또한 개체 C를 참조합니다. X의 단순 복사본은 개체 A와 B도 함께 참조하는 새 개체 X2를 만듭니다. 그러나 X의 전체 복사본은 새 개체 A2와 B2를 참조하는 새 개체 X2를 만듭니다. 새 개체 A2와 B2는 A와 B의 복사본이며 새 개체 C의 복사본인 C2를 참조합니다. 이 예제에서는 단순 복사와 전체 복사 작업 사이의 차이점을 보여 줍니다.

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

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

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

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

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

다음 예제에서는 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 개체를 반환합니다. 예제의 출력과 같이, MemberwiseClone 메서드를 호출하여 Person 개체를 복제한 경우 복제된 Person 개체는 동일한 Person.IdInfo 개체 참조를 공유하는 것을 제외하고 원본 개체로부터 독립적인 복사본입니다. 결과적으로, 클론의 Person.IdInfo 속성을 수정하면 원래 개체의 Person.IdInfo 속성이 변경됩니다. 반대로, 전체 복사 작업을 수행할 경우 Person.IdInfo 속성을 포함하여 복제된 Person 개체는 원본 개체에 영향을 미치지 않고 수정할 수 있습니다.

Windows Phone OS

지원되는 버전: 8.0, 7.1, 7.0

Windows Phone

표시:
© 2015 Microsoft