MemberwiseClone Methode
Dieser Artikel wurde maschinell übersetzt. Bewegen Sie den Mauszeiger über die Sätze im Artikel, um den Originaltext anzuzeigen. Weitere Informationen
Übersetzung
Original

Object.MemberwiseClone-Methode ()

 

Erstellt eine flache Kopie des aktuellen Object.

Namespace:   System
Assembly:  mscorlib (in mscorlib.dll)

protected object MemberwiseClone()

Rückgabewert

Type: System.Object

Eine flache Kopie des aktuellen Object.

Die MemberwiseClone -Methode erstellt eine flache Kopie, indem ein neues Objekt erstellen und anschließend die nicht statischen Felder des aktuellen Objekts in das neue Objekt kopiert.Wenn ein Feld ein Werttyp ist, wird eine Bit für Bit-Kopie des Feldes ausgeführt.Wenn ein Feld ein Referenztyp ist, wird der Verweis kopiert jedoch das genannte Objekt nicht. verweisen daher das ursprüngliche Objekt und der Klon auf dasselbe Objekt.

Betrachten Sie beispielsweise ein Objekt x, Objekte A und b verweist.Objekt B wiederum, verweist auf Objekt C.Eine flache Kopie von X erstellt neues Objekt X 2, das auch auf Objekte A und b verweistIm Gegensatz dazu erstellt eine tiefe Kopie von X ein neues Objekt X 2, das verweist auf die neuen Objekte A2 und B2, die Kopien von A und b.B2 verweist wiederum auf das neue Objekt C2, das ein Kopie-c istDas Beispiel veranschaulicht den Unterschied zwischen einer flachen und eine tiefe Kopie-Vorgang.

Es gibt zahlreiche Möglichkeiten, einen tiefe Kopie-Vorgang zu implementieren, wenn die flache Kopie-durch Vorgangs die MemberwiseClone Methode Ihre Anforderungen nicht erfüllt.Hierzu gehört Folgendes:

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

  • Rufen Sie die MemberwiseClone -Methode, um eine flache Kopie eines Objekts zu erstellen, und weisen Sie dann neue Objekte, deren Werte wie das ursprüngliche Objekt zu Eigenschaften oder Felder, deren Werte Verweistypen sind, identisch.Die DeepCopy -Methode im Beispiel veranschaulicht diesen Ansatz.

  • Serialisieren Sie das Objekt, um die Tiefe werden kopiert, und die serialisierten Daten auf einer anderen Objektvariable wiederhergestellt.

  • Verwenden Sie Reflektion mit Rekursion, zum Ausführen des Vorgangs tiefe Kopie.

Das folgende Beispiel veranschaulicht die MemberwiseClone Methode.Definiert eine ShallowCopy Methode, die aufgerufen der MemberwiseClone -Methode, um eine flache Kopie eines Vorgangs auf einem Person Objekt.Definiert auch eine DeepCopy Methode, die einen tiefe Kopie-Vorgang ausführt, auf ein Person Objekt.

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

In this example, the Person.IdInfo property returns an IdInfo object.As the output from the example shows, when a Person object is cloned by calling the MemberwiseClone method, the cloned Person object is an independent copy of the original object, except that they share the same Person.IdInfo object reference.As a result, modifying the clone's Person.IdInfo property changes the original object's Person.IdInfo property.On the other hand, when a deep copy operation is performed, the cloned Person object, including its Person.IdInfo property, can be modified without affecting the original object.

Universal Windows Platform
Verfügbar seit 4.5
.NET Framework
Verfügbar seit 1.1
Portable Class Library
Unterstützt in: portable .NET platforms
Silverlight
Verfügbar seit 2.0
Windows Phone Silverlight
Verfügbar seit 7.0
Windows Phone
Verfügbar seit 8.1
Zurück zum Anfang
Anzeigen:
© 2016 Microsoft