list::assign (STL Samples)
Muestra cómo utilizar la función de biblioteca de (STL) plantillas estándar de lista:: asignación en 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;
Comentarios
[!NOTA]
La clase y los nombres de parámetro en el prototipo no coincide con la versión del archivo de encabezado.Algunos se han modificado para mejorar la legibilidad.
La primera función miembro reemplaza por *this controlado secuencia con la secuencia [First, Last).La segunda función miembro reemplaza por *this controlado secuencia con una repetición de los elementos del valor n *x.*La tercera función miembro quita el elemento de la secuencia controlada designada por a él.La cuarta función miembro quita elementos de la secuencia controlada en el intervalo [First, Last).Ambos devuelven un iterador que designa el primer elemento que permanece más allá de cualquier elemento quitado, o final si no existe ese elemento.La función del último miembro devuelve TRUE para una secuencia controlada vacía.
Ejemplo
// 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
Requisitos
encabezado: <lista>