


std::vector-Iteratorfehler: eingehende Analyse
In der vorherigen Diskussion dieses Problems wissen wir alle, dass der Aufruf von std::vector::erase dies tun wird Nur den Iterator ungültig machen, der sich nach dem gelöschten Element befindet. Aber ist der Iterator an dieser Position nach dem Löschen eines Elements noch gültig (natürlich zeigt er nach dem Löschen nicht auf end())?
Ein Verständnis darüber, wie Vektoren implementiert werden, legt nahe, dass dieser Iterator definitiv verwendet werden kann, aber ich bin mir nicht sicher, ob dies zu undefiniertem Verhalten führt.
Als Beispiel entfernt der folgende Code alle ungeraden ganzen Zahlen aus einem Vektor. Verursacht dieser Code undefiniertes Verhalten?
<code class="cpp">typedef std::vector<int> vectype; vectype vec; for (int i = 0; i <p>Der Code läuft auf meinem Rechner einwandfrei, aber das überzeugt mich nicht von seiner Gültigkeit. </p> <h3 id="Gültigkeit-von-Iteratoren">Gültigkeit von Iteratoren</h3> <p><strong>Nicht</strong>; <strong>alle Iteratoren bei oder nach dem zum Löschen übergebenen Iterator werden ungültig</strong>. </p> <p>Erase gibt jedoch einen neuen Iterator zurück, der auf das Element nach dem gelöschten Element zeigt (oder auf das Ende, wenn es kein solches Element gibt). Mit diesem Iterator können Sie die Iteration fortsetzen. </p> <p>Beachten Sie, dass diese Methode zum Entfernen ungerader Elemente sehr ineffizient ist: Jedes Mal, wenn ein Element entfernt wird, müssen alle Elemente danach im Vektor um eine Position nach links verschoben werden (das ist O(n<sup>2). </sup>)). Mit dem Erase-Remove-Idiom können Sie diese Aufgabe effizienter (O(n)) erledigen. Sie können ein is_odd-Prädikat erstellen: </p> <pre class="brush:php;toolbar:false"><code class="cpp">bool is_odd(int x) { return (x % 2) == 1; }</code>
Anschließend können Sie es an remove_if übergeben:
<code class="cpp">vec.erase(std::remove_if(vec.begin(), vec.end(), is_odd), vec.end());</code>
Das obige ist der detaillierte Inhalt vonHier sind Artikeltitel, die Sie in Betracht ziehen können: **Ist es sicher, einen Iterator nach „std::vector::erase()' zu verwenden, wenn das Element gelöscht wird, auf das er verweist?** Der Titel stellt eine einfache Frage und spiegelt genau den Inhalt des Artikels wider, in dem untersucht wird, ob es möglich ist, einen Iterator, der auf ein Element verweist, nach dem Löschen weiterhin zu verwenden. Hier sind einige andere Optionen: * **ICH. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

GULC ist eine Hochleistungs-C-Bibliothek, die minimale Overheads, aggressive Einbeziehung und Compiler-Optimierung priorisiert. Ideal für leistungskritische Anwendungen wie Hochfrequenzhandel und eingebettete Systeme, sein Design betont die Einfachheit, Modul

In diesem Artikel werden die Funktionstypen zur Rückgabe von Funktionen (int, float, char usw.), abgeleitet (Arrays, Zeiger, Strukturen) und Hohlraumtypen enthält. Der Compiler bestimmt den Rückgabetyp über die Funktionserklärung und die Rückgabeerklärung unter der Durchsetzung

Dieser Artikel erläutert die C -Funktionserklärung im Vergleich zu Definition, Argumentübergabe (nach Wert und Zeiger), Rückgabetwerten und gemeinsamen Fallstricken wie Speicherlecks und Typenfehlanpassungen. Es betont die Bedeutung von Erklärungen für Modularität und Provi

In diesem Artikel wird die C -Funktion für die String -Fallkonvertierung beschrieben. Es erklärt mit toupper () und tolower () aus ctype.h, iteriert durch Saiten und Handhabung von Null -Terminatoren. Häufige Fallstricke wie das Vergessen von ctype.h und das Modifizieren von String -Literalen sind

Dieser Artikel untersucht die Speicher des C -Funktionsrückgabewerts. Kleine Renditewerte werden in der Regel in Registern für Geschwindigkeit gespeichert. Größere Werte können Zeiger zum Speicher verwenden (Stapel oder Heap), die die Lebensdauer beeinflussen und die manuelle Speicherverwaltung erfordern. Direkt ACC

Dieser Artikel analysiert die vielfältigen Verwendungen des Adjektivs "Unterscheidet", die seine grammatikalischen Funktionen, gemeinsame Phrasen (z. B. "unterscheidet sich von" "deutlich anders") und nuancierte Anwendung in formalen vs. informellen Anwendung

In diesem Artikel werden die C -Standard -Vorlagenbibliothek (STL) erläutert, die sich auf seine Kernkomponenten konzentriert: Container, Iteratoren, Algorithmen und Funktoren. Es wird beschrieben, wie diese interagieren, um die generische Programmierung, die Verbesserung der Codeeffizienz und die Lesbarkeit t zu ermöglichen

Dieser Artikel beschreibt die effiziente Verwendung von STL -Algorithmus in c. Es betont die Auswahl der Datenstruktur (Vektoren vs. Listen), Algorithmus -Komplexitätsanalyse (z. B. std :: sortieren vs. std :: partial_sort), Iteratoranwendungen und parallele Ausführung. Häufige Fallstricke wie


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Sicherer Prüfungsbrowser
Safe Exam Browser ist eine sichere Browserumgebung für die sichere Teilnahme an Online-Prüfungen. Diese Software verwandelt jeden Computer in einen sicheren Arbeitsplatz. Es kontrolliert den Zugriff auf alle Dienstprogramme und verhindert, dass Schüler nicht autorisierte Ressourcen nutzen.

SublimeText3 Linux neue Version
SublimeText3 Linux neueste Version

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)
