Практическое руководство. Создание конструктора копий (руководство по программированию на C#)

Для записей C# предоставляет конструктор копирования для объектов, но для классов его необходимо писать самостоятельно.

Внимание

Написание конструкторов копирования, работающих для всех производных типов в иерархии классов, может быть сложной задачей. Если класс не sealedявляется, следует настоятельно рассмотреть возможность создания иерархии record class типов для использования конструктора копирования, синтезированного компилятором.

Пример

В следующем примере классPerson определяет конструктор копии, который использует экземпляр Personв качестве аргумента. Значения свойств аргумента присваиваются свойствам нового экземпляра Person. Код содержит дополнительный конструктор копии, который отправляет свойства Name и Age экземпляра, который необходимо скопировать конструктору экземпляра класса. Класс Person имеет значение sealed, поэтому производные типы не могут быть объявлены, которые могут привести к ошибкам путем копирования только базового класса.

public sealed class Person
{
    // Copy constructor.
    public Person(Person previousPerson)
    {
        Name = previousPerson.Name;
        Age = previousPerson.Age;
    }

    //// Alternate copy constructor calls the instance constructor.
    //public Person(Person previousPerson)
    //    : this(previousPerson.Name, previousPerson.Age)
    //{
    //}

    // Instance constructor.
    public Person(string name, int age)
    {
        Name = name;
        Age = age;
    }

    public int Age { get; set; }

    public string Name { get; set; }

    public string Details()
    {
        return Name + " is " + Age.ToString();
    }
}

class TestPerson
{
    static void Main()
    {
        // Create a Person object by using the instance constructor.
        Person person1 = new Person("George", 40);

        // Create another Person object, copying person1.
        Person person2 = new Person(person1);

        // Change each person's age.
        person1.Age = 39;
        person2.Age = 41;

        // Change person2's name.
        person2.Name = "Charles";

        // Show details to verify that the name and age fields are distinct.
        Console.WriteLine(person1.Details());
        Console.WriteLine(person2.Details());

        // Keep the console window open in debug mode.
        Console.WriteLine("Press any key to exit.");
        Console.ReadKey();
    }
}
// Output:
// George is 39
// Charles is 41

См. также