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>