Object.MemberwiseClone Methode

Definition

Erstellt eine flache Kopie des aktuellen Object.

protected:
 System::Object ^ MemberwiseClone();
protected object MemberwiseClone ();
member this.MemberwiseClone : unit -> obj
Protected Function MemberwiseClone () As Object

Gibt zurück

Object

Eine flache Kopie des aktuellen Object.

Beispiele

Im folgenden Beispiel wird die MemberwiseClone -Methode veranschaulicht. Sie definiert eine ShallowCopy Methode, die die MemberwiseClone -Methode aufruft, um einen flachen Kopiervorgang für ein Person -Objekt auszuführen. Außerdem wird eine DeepCopy Methode definiert, die einen tiefen Kopiervorgang für ein Person -Objekt ausführt.

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(IdInfo.IdNumber);
       other.Name = String.Copy(Name);
       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 = 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
Public Class IdInfo
    Public IdNumber As Integer
    
    Public Sub New(IdNumber As Integer)
        Me.IdNumber = IdNumber
    End Sub
End Class

Public Class Person 
    Public Age As Integer
    Public Name As String
    Public IdInfo As IdInfo

    Public Function ShallowCopy() As Person
       Return DirectCast(Me.MemberwiseClone(), Person)
    End Function

    Public Function DeepCopy() As Person
       Dim other As Person = DirectCast(Me.MemberwiseClone(), Person) 
       other.IdInfo = New IdInfo(IdInfo.IdNumber)
       other.Name = String.Copy(Name)
       Return other
    End Function
End Class

Module Example
   Public Sub Main()
        ' Create an instance of Person and assign values to its fields.
        Dim p1 As New Person()
        p1.Age = 42
        p1.Name = "Sam"
        p1.IdInfo = New IdInfo(6565)

        ' Perform a shallow copy of p1 and assign it to p2.
        Dim p2 As 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)
        Console.WriteLine()
                
        ' 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("Values of p1 and p2 after changes to p1:")
        Console.WriteLine("   p1 instance values: ")
        DisplayValues(p1)
        Console.WriteLine("   p2 instance values:")
        DisplayValues(p2)
        Console.WriteLine()
        
        ' Make a deep copy of p1 and assign it to p3.
        Dim p3 As Person = 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("Values of p1 and p3 after changes to p1:")
        Console.WriteLine("   p1 instance values: ")
        DisplayValues(p1)
        Console.WriteLine("   p3 instance values:")
        DisplayValues(p3)
   End Sub
   
    Public Sub DisplayValues(p As Person)
        Console.WriteLine("      Name: {0:s}, Age: {1:d}", p.Name, p.Age)
        Console.WriteLine("      Value: {0:d}", p.IdInfo.IdNumber)
    End Sub
End Module
' The example displays the following output:
'       Original values of m1 and m2:
'          m1 instance values:
'             Name: Sam, Age: 42
'             Value: 6565
'          m2 instance values:
'             Name: Sam, Age: 42
'             Value: 6565
'       
'       Values of m1 and m2 after changes to m1:
'          m1 instance values:
'             Name: Frank, Age: 32
'             Value: 7878
'          m2 instance values:
'             Name: Sam, Age: 42
'             Value: 7878
'       
'       Values of m1 and m3 after changes to m1:
'          m1 instance values:
'             Name: George, Age: 39
'             Value: 8641
'          m3 instance values:
'             Name: Frank, Age: 32
'             Value: 7878

In diesem Beispiel gibt die Person.IdInfo -Eigenschaft ein IdInfo -Objekt zurück. Wie die Ausgabe des Beispiels zeigt, ist das geklonte Objekt, wenn ein Person -Objekt durch Aufrufen der -Methode geklont MemberwiseClone Person wird, eine unabhängige Kopie des ursprünglichen Objekts, mit der Ausnahme, dass sie denselben Person.IdInfo Objektverweis verwenden. Infolgedessen ändert das Ändern der -Eigenschaft des Person.IdInfo Klons die -Eigenschaft des ursprünglichen Person.IdInfo Objekts. Wenn dagegen ein tiefer Kopiervorgang ausgeführt wird, kann das geklonte Person Objekt, einschließlich seiner Person.IdInfo -Eigenschaft, geändert werden, ohne dass sich dies auf das ursprüngliche Objekt auswirkt.

Hinweise

Die MemberwiseClone -Methode erstellt eine flache Kopie, indem sie ein neues -Objekt erstellt und dann die nicht statischen Felder des aktuellen -Objekts in das neue -Objekt kopiert. Wenn ein Feld ein Werttyp ist, wird eine Bit-by-Bit-Kopie des Felds ausgeführt. Wenn ein Feld ein Verweistyp ist, wird der Verweis kopiert, aber das objekt, auf das verwiesen wird, nicht. daher verweisen das ursprüngliche Objekt und sein Klon auf das gleiche Objekt.

Betrachten Sie beispielsweise ein Objekt namens X, das auf die Objekte A und B verweist. Objekt B verweist wiederum auf Objekt C. Eine flache Kopie von X erstellt das neue Objekt X2, das auch auf die Objekte A und B verweist. Im Gegensatz dazu erstellt eine tiefe Kopie von X ein neues Objekt X2, das auf die neuen Objekte A2 und B2 verweist. Dabei handelt es sich um Kopien von A und B2. B2 verweist wiederum auf das neue Objekt C2, bei dem es sich um eine Kopie von C handelt. Das Beispiel veranschaulicht den Unterschied zwischen einem flachen und einem tiefen Kopiervorgang.

Es gibt zahlreiche Möglichkeiten, einen tiefen Kopiervorgang zu implementieren, wenn der flache Kopiervorgang, der von der -Methode ausgeführt wird, MemberwiseClone Ihre Anforderungen nicht erfüllt. Hierzu gehört Folgendes:

  • Rufen Sie einen Klassenkonstruktor des zu kopierenden Objekts auf, um ein zweites Objekt mit Eigenschaftswerten aus dem ersten Objekt zu erstellen. Dabei wird davon ausgegangen, dass die Werte eines Objekts vollständig durch seinen Klassenkonstruktor definiert werden.

  • Rufen Sie die MemberwiseClone -Methode auf, um eine flache Kopie eines Objekts zu erstellen, und weisen Sie dann allen Eigenschaften oder Feldern, deren Werte Verweistypen sind, neue Objekte zu, deren Werte mit dem ursprünglichen Objekt identisch sind. Die DeepCopy -Methode im Beispiel veranschaulicht diesen Ansatz.

  • Serialisieren Sie das Objekt so, dass es tief kopiert wird, und stellen Sie dann die serialisierten Daten in einer anderen Objektvariablen wieder her.

  • Verwenden Sie Reflektion mit Rekursion, um den Tiefenkopiervorgang auszuführen.

Gilt für