Heim Backend-Entwicklung C#.Net-Tutorial Die Fallstricke der Größe in stl

Die Fallstricke der Größe in stl

Nov 22, 2016 pm 03:12 PM
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()); }
Nach dem Login kopieren

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.


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

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Wie implementiert man einen benutzerdefinierten Komparator in C++ STL? Wie implementiert man einen benutzerdefinierten Komparator in C++ STL? Jun 05, 2024 am 11:50 AM

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.

Wie erhalte ich die Größe eines C++-STL-Containers? Wie erhalte ich die Größe eines C++-STL-Containers? Jun 05, 2024 pm 06:20 PM

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.

Wie entwerfe ich benutzerdefinierte STL-Funktionsobjekte, um die Wiederverwendbarkeit von Code zu verbessern? Wie entwerfe ich benutzerdefinierte STL-Funktionsobjekte, um die Wiederverwendbarkeit von Code zu verbessern? Apr 25, 2024 pm 02:57 PM

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

Wie gehe ich mit Hash-Kollisionen um, wenn ich C++ STL verwende? Wie gehe ich mit Hash-Kollisionen um, wenn ich C++ STL verwende? Jun 01, 2024 am 11:06 AM

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.

Wie verwende ich C++ STL, um Lesbarkeit und Wartbarkeit des Codes zu erreichen? Wie verwende ich C++ STL, um Lesbarkeit und Wartbarkeit des Codes zu erreichen? Jun 04, 2024 pm 06:08 PM

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.

Was sind die häufigsten Typen in C++-STL-Containern? Was sind die häufigsten Typen in C++-STL-Containern? Jun 02, 2024 pm 02:11 PM

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.

Wie sortiere ich C++-STL-Container? Wie sortiere ich C++-STL-Container? Jun 02, 2024 pm 08:22 PM

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.

Iteratoren in C++ STL Iteratoren in C++ STL Aug 21, 2023 pm 08:52 PM

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.

See all articles