Heim >Backend-Entwicklung >C++ >Wie kann man einen Vektor in C effizient mit seinem eigenen Inhalt erweitern?

Wie kann man einen Vektor in C effizient mit seinem eigenen Inhalt erweitern?

DDD
DDDOriginal
2024-11-11 07:57:02428Durchsuche

How to Efficiently Extend a Vector with its Own Content in C  ?

Effiziente Möglichkeit, Vector mit eigenem Inhalt zu erweitern

In C wird der Vektorcontainer häufig für die dynamische Speicherverwaltung verwendet. Wenn es darum geht, den Inhalt eines Vektors an sich selbst anzuhängen, ohne eine Schleife zu verwenden, suchen Entwickler oft nach einer effizienten Lösung.

Ein Ansatz besteht darin, die Funktion std::copy zu verwenden. Allerdings kann dies, wie in der Frage erwähnt, zu einem Segmentierungsfehler führen. Der Grund dafür ist, dass das einfache Kopieren der Elemente an das Ende des vorhandenen Vektors den von den ursprünglichen Elementen belegten Speicher überlappt.

Eine zuverlässigere Lösung verwendet eine Kombination aus std::resize und std::copy_n. Der folgende Codeausschnitt veranschaulicht diesen Ansatz:

auto old_count = xx.size();
xx.resize(2 * old_count);
std::copy_n(xx.begin(), old_count, xx.begin() + old_count);

Dieser Ansatz funktioniert, indem zunächst die Kapazität des Vektors mithilfe von std::resize erhöht wird. Da std::resize den Speicher bei Bedarf neu zuweist, müssen wir uns die ursprüngliche Größe mithilfe der Variablen old_count merken. Der nachfolgende std::copy_n-Vorgang kopiert die ursprünglichen Elemente in den neu zugewiesenen Speicher und dupliziert so effektiv den Inhalt des Vektors.

Eine Alternative zu std::resize ist std::reserve, das nur genug Speicher zuweist, um die angegebene Anzahl von Elementen aufzunehmen. Nach der Verwendung von std::reserve ist std::copy_n jedoch immer noch erforderlich, da der Enditerator ein Element über das Ende des Vektors hinaus zeigt, wodurch es für das Einfügen ungültig wird.

Es ist wichtig zu beachten, dass sowohl std::insert als auch std::push_back möglicherweise eine Neuzuweisung erfordern, wodurch vorhandene Iteratoren und Referenzen vor dem Einfügepunkt ungültig werden können. Um einen Vektor ohne Verwendung einer Schleife an sich selbst anzuhängen, eignet sich daher die Kombination von std::resize oder std::reserve und std::copy_n bietet eine zuverlässige und effiziente Lösung.

Das obige ist der detaillierte Inhalt vonWie kann man einen Vektor in C effizient mit seinem eigenen Inhalt erweitern?. 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