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.