Heim >Backend-Entwicklung >C++ >Sollten Sie von C-STL-Containern erben: Risiken und Alternativen?

Sollten Sie von C-STL-Containern erben: Risiken und Alternativen?

DDD
DDDOriginal
2024-11-26 14:13:101060Durchsuche

Should You Inherit from C   STL Containers: Risks and Alternatives?

Risiken der Ableitung von C-STL-Containern

Trotz der potenziellen Vorteile der Ableitung von Klassen aus C-STL-Containern, wie z. B. Funktionsüberladung und Vorlagenspezialisierung und verbessertem Debugging sind mit diesem Ansatz inhärente Risiken verbunden.

Bedenken Sie Folgendes Beispiel:

#include <vector>

class Rates : public std::vector<double> { };
class Charges : public std::vector<double> { };

int main() {
  auto p1 = new Rates;
  auto p2 = new Charges;
  kill_it(p2); // User code that knows nothing about Rates or Charges
  kill_it(p1);
  return 0;
}

Die kill_it-Funktion löscht den Speicher des Opfers, während der nicht-virtuelle Destruktor von std::vector ausgeführt wird. Dies kann zu potenziellen Problemen mit Charges (der abgeleiteten Klasse) führen, nicht jedoch mit Rates (der Typdefinition).

Das Problem entsteht, wenn der Benutzer versehentlich Fehler in die ??? der kill_it-Funktion einfügt. Abschnitt. Wenn der Benutzer beispielsweise p2 so ändert, dass er auf ein Rates-Objekt zeigt, bevor er kill_it(p2) aufruft, wird der nicht-virtuelle Destruktor von std::vector wird aufgerufen, was zu falschem Verhalten führt.

Um dieses Risiko zu mindern, wird im Allgemeinen empfohlen, beim Umgang mit STL-Containern Komposition anstelle von Ableitung zu verwenden. Die Zusammensetzung ermöglicht einen flexibleren und weniger fehleranfälligen Ansatz.

Das obige ist der detaillierte Inhalt vonSollten Sie von C-STL-Containern erben: Risiken und Alternativen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn