Verwenden der STL-Funktion list::list in Visual C++
In diesem Artikel wird die Verwendung der list::list
STL-Funktion in Visual C++ veranschaulicht.
Ursprüngliche Produktversion: Visual C++
Ursprüngliche KB-Nummer: 158091
Erforderlicher Header
<list>
Prototyp
explicit list(const A& al = A());
explicit list(size_type n, const T& v = T(), const A& al = A());
list(const list& x);
list(const_iterator first, const_iterator last, const A& al = A());
Hinweis
Die Klassen-/Parameternamen im Prototyp stimmen möglicherweise nicht mit der Version in der Headerdatei überein. Einige wurden geändert, um die Lesbarkeit zu verbessern.
Beschreibung
Der erste Konstruktor gibt eine leere anfängliche kontrollierte Sequenz an. Der zweite Konstruktor gibt eine Wiederholung von n
Elementen des Werts x
an. Der dritte Konstruktor gibt eine Kopie der sequenz an, die von gesteuert wird x
. Der letzte Konstruktor gibt die Sequenz an (first
, last
). Alle Konstruktoren speichern das Zuweisungsobjekt al
oder für den Kopierkonstruktor in x.get_allocator()
der Zuweisung und initialisieren die gesteuerte Sequenz.
Beispielcode
//////////////////////////////////////////////////////////////////////
// Compile options needed: -GX
// list.cpp : demonstrates the different constructors for list<T>
// Functions:
// list::list
// Copyright (c) 1996 Microsoft Corporation. All rights reserved.
//////////////////////////////////////////////////////////////////////
#include <list>
#include <string>
#include <iostream>
#if _MSC_VER > 1020 // if VC++ version is > 4.2
using namespace std; // std c++ libs implemented in std
#endif
typedef list<string, allocator<string> > LISTSTR;
// Try each of the four constructors
void main()
{
LISTSTR::iterator i;
LISTSTR test; // default constructor
test.insert(test.end(), "one");
test.insert(test.end(), "two");
LISTSTR test2(test); // construct from another list
LISTSTR test3(3, "three"); // add several <T>'s
LISTSTR test4(++test3.begin(), // add part of another list
test3.end());
// Print them all out
// one two
for (i = test.begin(); i != test.end(); ++i)
cout << *i << " ";
cout << endl;
// one two
for (i = test2.begin(); i != test2.end(); ++i)
cout << *i << " ";
cout << endl;
// three three three
for (i = test3.begin(); i != test3.end(); ++i)
cout << *i << " ";
cout << endl;
// three three
for (i = test4.begin(); i != test4.end(); ++i)
cout << *i << " ";
cout << endl;
}
Die Programmausgabe lautet:
one two
one two
three three three
three three
Feedback
https://aka.ms/ContentUserFeedback.
Bald verfügbar: Im Laufe des Jahres 2024 werden wir GitHub-Issues stufenweise als Feedbackmechanismus für Inhalte abbauen und durch ein neues Feedbacksystem ersetzen. Weitere Informationen finden Sie unterFeedback senden und anzeigen für