Heim > Backend-Entwicklung > C++ > Wie lösche ich Elemente während der Iteration sicher aus einem std::vector?

Wie lösche ich Elemente während der Iteration sicher aus einem std::vector?

Barbara Streisand
Freigeben: 2024-11-01 12:24:02
Original
1011 Leute haben es durchsucht

How to Safely Erase Elements From a std::vector During Iteration?

Löschen von Elementen aus einem std::vector während der Iteration: Strategien und Leistung

Beim Durchlaufen eines std::vector, während gelöscht werden muss Bei der Verwendung von Elementen, die auf einer Bedingung basieren, kann der herkömmliche Ansatz mit einer for-Schleife mit Iteratoren zu Problemen führen. Durch das Löschen eines Elements wird der Iterator ungültig, wodurch die Schleife unvollständig wird. Um dieser Herausforderung zu begegnen, untersuchen wir optimale Strategien für den Umgang mit solchen Szenarien.

Iterieren mit Invalidierungsverfolgung

Ein Ansatz besteht darin, die durch das Löschen von Elementen verursachte Iterator-Invalidierung explizit zu verfolgen. Im bereitgestellten Beispielcode:

<code class="cpp">for (iterator it = begin; it != end(container) /* !!! */; )
{
    if (it->somecondition())
    {
        it = vec.erase(it); // Returns the new iterator to continue from.
    }
    else
    {
        ++it;
    }
}</code>
Nach dem Login kopieren

Der Hauptunterschied besteht hier in der Verwendung von end(container) anstelle eines vorberechneten Endes, das die Iteratorreferenz nach jedem Löschvorgang aktualisiert. Dadurch werden gültige Iteratorvergleiche während der Schleife sichergestellt.

Kombinieren von std::remove_if und erase

Ein effizienterer Ansatz besteht darin, die Funktionen std::remove_if und erase zu kombinieren. Dies optimiert den Prozess, indem die Notwendigkeit einer Ungültigkeitsverfolgung entfällt:

<code class="cpp">iterator it = std::remove_if(begin, end, pred);
vec.erase(it, vec.end());</code>
Nach dem Login kopieren

Hier stellt pred ein Entfernungsprädikat dar, das bestimmt, welche Elemente entfernt werden sollen. Dieser Ansatz eliminiert die mit iteriertem Löschen verbundene O(N^2)-Komplexität und verbessert die Leistung von O(N).

Beispielanwendungen

Im bereitgestellten Codebeispiel Die RemoveTimedEvent-Struktur dient als Entfernungsprädikat, um Ereignisse zu identifizieren und zu entfernen, die mit einem bestimmten Widget in einem Vektor zeitgesteuerter Ereignisse verknüpft sind.

Durch die Nutzung einer dieser Strategien können Sie Elemente währenddessen effektiv aus einem std::vector löschen Iteration unter Beibehaltung der korrekten Iteratorfunktionalität und -leistung.

Das obige ist der detaillierte Inhalt vonWie lösche ich Elemente während der Iteration sicher aus einem std::vector?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage