Heim > Backend-Entwicklung > C++ > Ist „std::list::size()' immer O(1)?

Ist „std::list::size()' immer O(1)?

Barbara Streisand
Freigeben: 2024-11-24 04:30:10
Original
244 Leute haben es durchsucht

Is `std::list::size()` Always O(1)?

Ist list::size() wirklich O(1)?

Während es einst wahr war, dass std::list::size () in allen Implementierungen eine variable Komplexität aufwies, hat C 11 sein Verhalten standardisiert. Tabelle 96 der Containeranforderungen schreibt eine konstante Komplexität (O(1)) für .size()-Operationen für alle Standardcontainer vor.

Eine bemerkenswerte Ausnahme bleibt jedoch die libstdc-Implementierung von gcc vor Version 5.0. Trotz der C 11-Standardanforderung verwendet seine .size()-Funktion einen O(N)-Algorithmus, wie im folgenden Auszug zu sehen ist:

size_type
size() const _GLIBCXX_NOEXCEPT
{ return std::distance(begin(), end()); }
Nach dem Login kopieren

Diese Entscheidung ergibt sich aus Optimierungsüberlegungen innerhalb von libstdc. Die Beibehaltung einer separaten Anzahl von Elementen anstelle des Durchlaufens der Liste verbessert die Leistung für einige Anwendungsfälle, obwohl dies im Widerspruch zur Standardkomplexitätsanforderung steht.

Die Implementierung von Libc hält sich dagegen korrekt an die O(1) Komplexität, wie durch den folgenden Codeausschnitt veranschaulicht:

_LIBCPP_INLINE_VISIBILITY
size_type size() const _NOEXCEPT     {return base::__sz();}

...

__compressed_pair<size_type, __node_allocator> __size_alloc_;

_LIBCPP_INLINE_VISIBILITY
const size_type&amp; __sz() const _NOEXCEPT
    {return __size_alloc_.first();}
Nach dem Login kopieren

Zusammenfassend lässt sich sagen, dass der C 11-Standard O(1)-Komplexität für vorschreibt std::list::size(), die libstdc-Implementierung von gcc vor Version 5.0 bleibt eine Anomalie und verwendet stattdessen einen O(N)-Algorithmus.

Das obige ist der detaillierte Inhalt vonIst „std::list::size()' immer O(1)?. 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