Freigeben über


Verwenden der Funktion list::list STL in Visual C++

In diesem Artikel wird die Verwendung der list::list STL-Funktion in Visual C++ veranschaulicht.

Originalproduktversion: 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());

Notiz

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 Wertenelementen xan. Der dritte Konstruktor gibt eine Kopie der Sequenz an, die von x. Der letzte Konstruktor gibt die Sequenz (first, last). Alle Konstruktoren speichern das Allocator-Objekt aloder für den Kopierkonstruktor, x.get_allocator()in allocator und initialisieren die kontrollierte 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