Benutzerdefinierter Kopierkonstruktor in C
In C generiert der Compiler normalerweise einen Standard-Kopierkonstruktor für Klassen, der mitgliederweise arbeitet Kopieren. In bestimmten Szenarien ist jedoch ein benutzerdefinierter Kopierkonstruktor erforderlich.
Wann wird ein benutzerdefinierter Kopierkonstruktor benötigt?
Ein benutzerdefinierter Kopierkonstruktor ist erforderlich Erforderlich, wenn das mitgliedweise Kopierverhalten des Standardkopierkonstruktors nicht ausreicht. Betrachten Sie das folgende Beispiel:
<code class="cpp">class Class { public: Class(const char* str); ~Class(); private: char* stored; }; Class::Class(const char* str) { stored = new char[srtlen(str) + 1]; strcpy(stored, str); } Class::~Class() { delete[] stored; }</code>
In diesem Beispiel würde der Standard-Kopierkonstruktor einfach den Zeiger auf das gespeicherte Mitglied kopieren, anstatt den zugrunde liegenden Puffer zu duplizieren. Dies kann zu undefiniertem Verhalten führen, wenn eine Kopie vor der anderen zerstört wird.
Benutzerdefinierter Kopierkonstruktor
Um dieses Problem zu beheben, können Sie eine benutzerdefinierte Kopie definieren Konstruktor, der tiefes Kopieren durchführt:
<code class="cpp">Class::Class(const Class& another) { stored = new char[strlen(another.stored) + 1]; strcpy(stored, another.stored); }</code>
Dieser Kopierkonstruktor weist neuen Speicher zu und kopiert den Inhalt des gespeicherten Mitglieds, wodurch sichergestellt wird, dass beide Kopien über ihre eigenen unabhängigen Puffer verfügen.
Das obige ist der detaillierte Inhalt vonWann ist ein benutzerdefinierter Kopierkonstruktor in C erforderlich?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!