Condividi tramite


list::assign (STL Samples)

Viene illustrato come utilizzare elenco:: assegnare Funzione della libreria di modelli standard (STL) in Visual C++.

void assign(
   const_iterator First,
   const_iterator Last
);
void assign(
   size_type n,
   const T& x = T( )
);
iterator erase(
   iterator It
);
iterator erase(
   iterator First,
   iterator Last
); bool empty( ) const;

Note

[!NOTA]

La classe/nomi di parametro nel prototipo non corrisponde alla versione nel file di intestazione.alcuni sono stati modificati per migliorare la leggibilità.

La prima funzione membro sostituisce la sequenza controllata da *ciò con la sequenza [First, Last).La seconda funzione membro sostituisce la sequenza controllata da *ciò con una ripetizione degli elementi di n di valore x.La terza funzione membro rimuove l'elemento della sequenza selezionata indicata da .La quarta funzione membro rimuove gli elementi della sequenza selezionata nell'intervallo [First, Last).Entrambe restituiscono un iteratore che definisce il primo elemento rimanente oltre tutti gli elementi eliminati, o estremità se tale elemento non esiste.Gli ultimi risultati delle funzioni membro true per una sequenza controllata vuota.

Esempio

// assign.cpp 
// compile with: /EHsc
//
// Shows various ways to assign and erase elements
//        from a list<T>.
//
// Functions:
//    list::assign
//    list::empty
//    list::erase

#include <list>
#include <iostream>

using namespace std ;

typedef list<int> LISTINT;

int main()
{
    LISTINT listOne;
    LISTINT listAnother;
    LISTINT::iterator i;

    // Add some data
    listOne.push_front (2);
    listOne.push_front (1);
    listOne.push_back (3);

    listAnother.push_front(4);

    listAnother.assign(listOne.begin(), listOne.end());

    // 1 2 3
    for (i = listAnother.begin(); i != listAnother.end(); ++i)
        cout << *i << " ";
    cout << endl;

    listAnother.assign(4, 1);

    // 1 1 1 1
    for (i = listAnother.begin(); i != listAnother.end(); ++i)
        cout << *i << " ";
    cout << endl;

    listAnother.erase(listAnother.begin());

    // 1 1 1
    for (i = listAnother.begin(); i != listAnother.end(); ++i)
        cout << *i << " ";
    cout << endl;

    listAnother.erase(listAnother.begin(), listAnother.end());
    if (listAnother.empty())
        cout << "All gone\n";
}

Output

1 2 3 
1 1 1 1 
1 1 1 
All gone

Requisiti

intestazione: <elenco>

Vedere anche

Concetti

Esempi di una libreria di modelli standard