C ++ - Bibliothek - <Deque>
Einführung
Deque ist die Abkürzung für Double Ended Queue. Es ist ein Sequenzcontainer, der seine Laufzeitgröße ändern kann. Container ist ein Objekt, das Daten des gleichen Typs enthält. Sequenzcontainer speichern Elemente streng linear.
Deque-Elemente können in verschiedenen Speicherblöcken verstreut sein. Der Container speichert die erforderlichen Informationen, um in konstanter Zeit direkten Zugriff auf jedes Element zu ermöglichen. Im Gegensatz zu Vektoren kann bei deque nicht garantiert werden, dass alle Elemente an zusammenhängenden Speicherorten gespeichert werden. Daher ist kein direkter Zugriff auf Daten durch Versetzen von Zeigern möglich. Es ermöglicht jedoch den direkten Zugriff auf jedes Element mit dem Indexoperator [].
Deque kann zur Laufzeit an beiden Enden zur Laufzeit schrumpfen oder expandieren. Die Speicheranforderung wird automatisch vom internen Allokator erfüllt . Deque bietet ähnliche Funktionen wie Vektoren, bietet jedoch eine effiziente Möglichkeit, Daten von jedem Ende aus einzufügen und zu löschen.
Deques mit der Größe Null sind ebenfalls gültig. In diesem Fall zeigen deque.begin () und deque.end () auf dieselbe Position. Das Verhalten beim Aufrufen von front () oder back () ist jedoch undefiniert.
Definition
Unten finden Sie die Definition von std :: deque aus der <deque> -Headerdatei
template < class T, class Alloc = allocator<T> > class deque;
Parameter
T - Typ des enthaltenen Elements.
T kann durch einen anderen Datentyp einschließlich eines benutzerdefinierten Typs ersetzt werden.
Alloc - Typ des Allokatorobjekts.
Standardmäßig wird die Allokatorklassenvorlage verwendet, die das einfachste Speicherzuordnungsmodell definiert und wertunabhängig ist.
Mitgliedertypen
Die folgenden Elementtypen können von Elementfunktionen als Parameter oder Rückgabetyp verwendet werden.
Sr.Nr. | Mitgliedertypen | Definition |
---|---|---|
1 | Werttyp | T (Erster Parameter der Vorlage) |
2 | allocator_type | Alloc (Zweiter Parameter der Vorlage) |
3 | Referenz | Werttyp& |
4 | const_reference | const value_type & |
5 | Zeiger | Werttyp* |
6 | const_pointer | const value_type * |
7 | Iterator | ein Iterator mit wahlfreiem Zugriff auf value_type |
8 | const_iterator | ein Iterator mit wahlfreiem Zugriff auf const value_type |
9 | reverse_iterator | std :: reverse_iterator <iterator> |
10 | const_reverse_iterator | std :: reverse_iterator <const_iterator> |
11 | size_type | size_t |
12 | Differenztyp | ptrdiff_t |
Funktionen von <deque>
Unten finden Sie eine Liste aller Methoden aus dem <deque> -Header.
Konstruktoren
Sr.Nr. | Methode & Beschreibung |
---|---|
1 | deque :: deque Standardkonstruktor Konstruiert eine leere Deque mit dem Element Null. |
2 | deque :: deque fill Konstruktor Konstruieren Sie eine neue Deque mit n Elementen und weisen Sie jedem Deque-Element val zu |
3 | deque :: deque range Konstruktor Konstruiert eine Deque mit so vielen Elementen wie im Bereich der ersten bis letzten . |
4 | deque :: deque copy Konstruktor Erstellt eine Deque mit einer Kopie aller im vorhandenen Container vorhandenen Elemente. |
5 | deque :: deque move Konstruktor Konstruiert eine Deque mit dem Inhalt anderer mithilfe der Verschiebungssemantik. |
6 | Konstruktor der deque :: deque- Initialisiererliste Erstellt eine Deque aus der Initialisierungsliste. |
Zerstörer
Sr.Nr. | Methode & Beschreibung |
---|---|
1 | deque :: ~ deque Zerstört deque Objekt durch Freigabe seines Speichers. |
Mitgliedsfunktionen
Sr.Nr. | Methode & Beschreibung |
---|---|
1 | deque :: Range-Version zuweisen Weisen Sie den Deque-Elementen neue Werte zu, indem Sie alte ersetzen. |
2 | deque :: fülle die Füllversion zu Weisen Sie den Deque-Elementen neue Werte zu, indem Sie alte ersetzen. |
3 | deque :: Initialisiererlistenversion zuweisen Weisen Sie den Deque-Elementen neue Werte zu, indem Sie alte ersetzen. |
4 | deque :: at Gibt den Verweis auf das Element zurück, das an Position n in der Deque vorhanden ist. |
5 | deque :: zurück Gibt einen Verweis auf das letzte Element der Deque zurück. |
6 | deque :: begin Gibt einen Iterator mit wahlfreiem Zugriff zurück, der auf das erste Element der Deque zeigt. |
7 | deque :: cbegin Gibt einen konstanten Iterator mit wahlfreiem Zugriff zurück, der auf den Beginn der Deque zeigt. |
8 | deque :: cend Gibt einen konstanten Iterator mit wahlfreiem Zugriff zurück, der auf den Beginn der Deque zeigt. |
9 | deque :: clear Zerstört die Deque, indem alle Elemente aus der Deque entfernt werden, und setzt die Deque-Größe auf Null. |
10 | deque :: crbegin Gibt einen konstanten Umkehriterator zurück, der auf den Umkehreranfang des Containers zeigt. |
11 | deque :: crend Gibt einen konstanten Umkehriterator zurück, der auf das umgekehrte Ende der Deque zeigt. |
12 | deque :: emplace Erweitert den Container durch Einfügen eines neuen Elements an der Position . |
13 | deque :: emplace_back Fügt am Ende der Deque ein neues Element ein. |
14 | deque :: emplace_front Fügt zu Beginn der Deque ein neues Element ein. |
15 | deque :: leer Testet, ob deque leer ist oder nicht. |
16 | deque :: end Gibt einen Iterator zurück, der auf das Element am Ende des Deque-Containers verweist . |
17 | deque :: erase position version Entfernt ein einzelnes Element aus der Deque. |
18 | deque :: erase range version Entfernt ein einzelnes Element aus der Deque. |
19 | deque :: front Gibt einen Verweis auf das erste Element der Deque zurück |
20 | deque :: get_allocator Gibt einen mit deque verknüpften Allokator zurück |
21 | deque :: Einzelelementversion einfügen Erweitert den Container durch Einfügen eines neuen Elements an der Position. |
22 | deque :: insert fill Version Erweitert den Container durch Einfügen eines neuen Elements in den Container. |
23 | deque :: insert range version Erweitert den Container durch Einfügen eines neuen Elements in den Container. |
24 | deque :: insert move version Erweitert den Container durch Einfügen eines neuen Elements in den Container. |
25 | deque :: Initialisierungslistenversion einfügen Erweitert den Container durch Einfügen eines neuen Elements in den Container. |
26 | deque :: max_size Gibt die maximale Anzahl von Elementen zurück, die von deque gehalten werden können. |
27 | deque :: operator = Version kopieren Weisen Sie der Deque neue Inhalte zu, indem Sie alte ersetzen, und ändern Sie gegebenenfalls die Größe. |
28 | deque :: operator = Version verschieben Weisen Sie der Deque neue Inhalte zu, indem Sie alte ersetzen, und ändern Sie gegebenenfalls die Größe. |
29 | deque :: operator = Version der Initialisierungsliste Weisen Sie der Deque neue Inhalte zu, indem Sie alte ersetzen, und ändern Sie gegebenenfalls die Größe. |
30 | deque :: operator [] Gibt einen Verweis auf das an Position n vorhandene Element zurück . |
31 | deque :: pop_back Entfernt das letzte Element aus der Deque und reduziert die Größe der Deque um eins. |
32 | deque :: pop_front Entfernt das erste Element aus der Deque und reduziert die Größe der Deque um eins. |
33 | deque :: push_back Fügt am Ende der Deque ein neues Element ein und erhöht die Deque-Größe um eins. |
34 | deque :: push_back move version Fügt am Ende der Deque ein neues Element ein und erhöht die Deque-Größe um eins. |
35 | deque :: push_front Fügt ein neues Element an der Vorderseite der Deque ein und vergrößert die Deque um eins. |
36 | deque :: push_front move version Fügt ein neues Element an der Vorderseite der Deque ein und vergrößert die Deque um eins. |
37 | deque :: rbegin Gibt einen umgekehrten Iterator zurück, der auf das letzte Element der Deque zeigt. |
38 | deque :: rend Gibt einen umgekehrten Iterator zurück, der auf das umgekehrte Ende der Deque zeigt. |
39 | deque :: resize Ändert die Größe der Deque. |
40 | deque :: resize value version Ändert die Größe der Deque. |
41 | deque :: shrink_to_fit Fordert den Container auf, seine Kapazität an seine Größe anzupassen. |
42 | deque :: size Gibt die Anzahl der in der Deque vorhandenen Elemente zurück. |
43 | deque :: swap Tauscht den Inhalt der Deque gegen den Inhalt einer anderen Deque x aus . |
Überladene Funktionen ohne Mitglieder
Sr.Nr. | Methode & Beschreibung |
---|---|
1 | operator == Testet, ob zwei Deques gleich sind oder nicht. |
2 | Operator! = Testet, ob zwei Deques gleich sind oder nicht. |
3 | Operator < Testet, ob die erste Deque geringer als die andere ist oder nicht. |
4 | Operator <= Testet, ob die erste Deque kleiner oder gleich der anderen ist oder nicht. |
5 | Betreiber> Testet, ob die erste Deque größer als die andere ist oder nicht. |
6 | Operator> = Testet, ob die erste Deque größer oder gleich der anderen ist oder nicht. |
7 | Tauschen Tauscht den Inhalt von zwei Deque aus. |