Die Fallstricke der Größe in stl
Als ich letztes Jahr zum ersten Mal in das Unternehmen eintrat, gab es LRUCache in der Basisbibliothek des Unternehmens und seine Implementierung verwendete std::list. Aber die Funktion, die std::list berechnet, verwendet direkt die size()-Methode in stl. Dadurch blieb die Leistung während des Stresstests hier hängen.
Heute hat ein Kollege eine weitere Warteschlangenimplementierung in der Basisbibliothek gefunden, die ebenfalls std::list verwendet. Die size()-Methode wurde auch beim Abrufen der Anzahl der Elemente verwendet.
Leider stellt die Basisbibliothek des Unternehmens nur Header-Dateien bereit, und es ist unmöglich, einzeln zu überprüfen, ob diese Grube an anderen Stellen vorhanden ist.
Werfen wir einen Blick auf die Implementierung der size()-Methode in stl:
size_type size() const { return std::distance(begin(), end()); }
Die obige Code-G-Version ist 4.2.1
Offensichtlich die Komplexität ist O(N ). Wenn die Liste viele Elemente enthält, ist die Berechnung sehr langsam. Daher müssen Sie bei der Verwendung von std::list daran denken, selbst eine Zählung zu führen.

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

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

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Die Implementierung eines benutzerdefinierten Komparators kann durch die Erstellung einer Klasse erreicht werden, die „operator()“ überlädt, zwei Parameter akzeptiert und das Ergebnis des Vergleichs anzeigt. Beispielsweise sortiert die StringLengthComparator-Klasse Zeichenfolgen, indem sie ihre Längen vergleicht: Erstellen Sie eine Klasse, überladen Sie „operator()“ und geben Sie einen booleschen Wert zurück, der das Vergleichsergebnis angibt. Verwendung benutzerdefinierter Komparatoren zum Sortieren in Containeralgorithmen. Mit benutzerdefinierten Komparatoren können wir Daten anhand benutzerdefinierter Kriterien sortieren oder vergleichen, selbst wenn wir benutzerdefinierte Vergleichskriterien verwenden müssen.

Sie können die Anzahl der Elemente in einem Container ermitteln, indem Sie die Memberfunktion size() des Containers verwenden. Beispielsweise gibt die Funktion size() des Vektorcontainers die Anzahl der Elemente zurück, die Funktion size() des Listencontainers gibt die Anzahl der Elemente zurück, die Funktion length() des Zeichenfolgencontainers gibt die Anzahl der Zeichen zurück und die Die Funktion Capacity() des Deque-Containers gibt die Anzahl der zugewiesenen Speicherblöcke zurück.

Die Verwendung von STL-Funktionsobjekten kann die Wiederverwendbarkeit verbessern und umfasst die folgenden Schritte: Definieren Sie die Funktionsobjektschnittstelle (erstellen Sie eine Klasse und erben Sie von std::unary_function oder std::binary_function). Überladen Sie „operator()“, um das Funktionsverhalten im überladenen „operator()“ zu definieren. Implementieren Sie die erforderliche Funktionalität durch STL-Algorithmen (z. B. std::transform) mithilfe von Funktionsobjekten

Die Methoden zur Behandlung von C++STL-Hash-Konflikten sind: Kettenadressmethode: Verwendung verknüpfter Listen zum Speichern widersprüchlicher Elemente, was eine gute Anwendbarkeit bietet. Offene Adressierungsmethode: Finden Sie verfügbare Speicherorte im Bucket, um Elemente zu speichern. Die Untermethoden sind: Lineare Erkennung: Finden Sie den nächsten verfügbaren Speicherort in der Reihenfolge. Quadratische Erkennung: Suche durch Überspringen von Positionen in quadratischer Form.

Durch die Verwendung der C++-Standardvorlagenbibliothek (STL) können wir die Lesbarkeit und Wartbarkeit des Codes verbessern: 1. Verwenden Sie Container, um primitive Arrays zu ersetzen, um die Typsicherheit und Speicherverwaltung zu verbessern. 2. Verwenden Sie Algorithmen, um komplexe Aufgaben zu vereinfachen und die Effizienz zu verbessern. 3. .Verwenden Sie Iteratoren, um die Durchquerung zu verbessern und den Code zu vereinfachen. 4.Verwenden Sie intelligente Zeiger, um die Speicherverwaltung zu verbessern und Speicherlecks und baumelnde Zeiger zu reduzieren.

Die häufigsten Containertypen in C++STL sind Vector, List, Deque, Set, Map, Stack und Queue. Diese Container bieten Lösungen für unterschiedliche Datenspeicheranforderungen, z. B. dynamische Arrays, doppelt verknüpfte Listen sowie schlüssel- und wertbasierte assoziative Container. In der Praxis können wir STL-Container verwenden, um Daten effizient zu organisieren und darauf zuzugreifen, beispielsweise um Schülernoten zu speichern.

So sortieren Sie STL-Container in C++: Verwenden Sie die Funktion sort(), um Container an Ort und Stelle zu sortieren, z. B. std::vector. Mithilfe der geordneten Container std::set und std::map werden Elemente beim Einfügen automatisch sortiert. Für eine benutzerdefinierte Sortierreihenfolge können Sie eine benutzerdefinierte Komparatorklasse verwenden, um beispielsweise einen Vektor von Zeichenfolgen alphabetisch zu sortieren.

C++STL (StandardTemplateLibrary) ist eine der Standardbibliotheken der Programmiersprache C++. Sie enthält eine Reihe von Standarddatenstrukturen und -algorithmen. In STL ist der Iterator (Iterator) ein sehr wichtiges Werkzeug zum Durchlaufen und Zugreifen auf STL-Container. Ein Iterator ist ein zeigerähnliches Objekt, das auf ein Element in einem Container (z. B. Vektor, Liste, Menge, Karte usw.) zeigen und im Container verschoben werden kann.
