Condividi tramite


list::list

Crea un elenco di dimensioni o con gli elementi di un valore specifico o con un allocatore specifico o come copia di tutto o parte di un altro elenco.

list( );
explicit list(
   const Allocator& _Al
);
explicit list(
   size_type _Count
);
list(
   size_type _Count,
   const Type& _Val
);
list(
   size_type _Count,
   const Type& _Val,
   const Allocator& _Al
);
list(
   const list& _Right
);
template<class InputIterator>
   list(
      InputIterator _First,
      InputIterator _Last
   );
template<class InputIterator >
   list(
      InputIterator _First,
      InputIterator _Last,
      const Allocator& _Al
   );
list(
   list&& _Right
);

Parametri

Parametro

Descrizione

_Al

Classe dell'allocatore da utilizzare con questo oggetto.

_Count

Il numero di elementi nell'elenco costruito.

_Val

Il valore degli elementi nell'elenco costruito.

_Right

L'elenco dell'elenco viene costruito da una copia.

_First

La posizione del primo elemento nella sequenza di elementi da copiare.

_Last

La posizione del primo elemento nell'intervallo di elementi da copiare.

Note

Tutti i costruttori archiviano un oggetto allocatore_Al() e inizializzano l'elenco.

get_allocator restituisce una copia dell'oggetto allocatore utilizzato per costruire un elenco.

I primi due costruttori specificano un elenco vuoto iniziale, il secondo specifica il tipo di_Alallocatore () da utilizzare.

Il terzo costruttore specifica una ripetizione di un numero specificato ()_Countdegli elementi di valore predefinito per una classe Tipo.

I il quarto e quinti costruttori specificano una ripetizione di elementi ()_Countdi valore _Val.

Il sesto costruttore specifica una copia dell'elenco _Right.

I due costruttori seguenti copia dell'intervallo [_First, _Last) di un elenco.

L'ultimo costruttore dell'elenco _Right.

Nessuno dei costruttori eseguono tutti i riallocazioni provvisori.

Esempio

// list_class_list.cpp
// compile with: /EHsc
#include <list>
#include <iostream>

int main( ) 
{
   using namespace std;
   list <int>::iterator c1_Iter, c2_Iter, c3_Iter, c4_Iter, c5_Iter, c6_Iter, c7_Iter;

   // Create an empty list c0
   list <int> c0;

   // Create a list c1 with 3 elements of default value 0
   list <int> c1( 3 );

   // Create a list c2 with 5 elements of value 2
   list <int> c2( 5, 2 );

   // Create a list c3 with 3 elements of value 1 and with the 
   // allocator of list c2
   list <int> c3( 3, 1, c2.get_allocator( ) );

   // Create a copy, list c4, of list c2
   list <int> c4(c2);

   // Create a list c5 by copying the range c4[_First, _Last)
   c4_Iter = c4.begin( );
   c4_Iter++;
   c4_Iter++;
   list <int> c5( c4.begin( ), c4_Iter );

   // Create a list c6 by copying the range c4[_First, _Last) and with 
   // the allocator of list c2
   c4_Iter = c4.begin( );
   c4_Iter++;
   c4_Iter++;
   c4_Iter++;
   list <int> c6( c4.begin( ), c4_Iter, c2.get_allocator( ) );

   cout << "c1 =";
   for ( c1_Iter = c1.begin( ); c1_Iter != c1.end( ); c1_Iter++ )
      cout << " " << *c1_Iter;
   cout << endl;
   
   cout << "c2 =";
   for ( c2_Iter = c2.begin( ); c2_Iter != c2.end( ); c2_Iter++ )
      cout << " " << *c2_Iter;
   cout << endl;

   cout << "c3 =";
   for ( c3_Iter = c3.begin( ); c3_Iter != c3.end( ); c3_Iter++ )
      cout << " " << *c3_Iter;
   cout << endl;

   cout << "c4 =";
   for ( c4_Iter = c4.begin( ); c4_Iter != c4.end( ); c4_Iter++ )
      cout << " " << *c4_Iter;
   cout << endl;

   cout << "c5 =";
   for ( c5_Iter = c5.begin( ); c5_Iter != c5.end( ); c5_Iter++ )
      cout << " " << *c5_Iter;
   cout << endl;

   cout << "c6 =";
   for ( c6_Iter = c6.begin( ); c6_Iter != c6.end( ); c6_Iter++ )
      cout << " " << *c6_Iter;
   cout << endl;

   // Move list c6 to list c7
   list <int> c7( move(c6) );
   list <int>::iterator c7_Iter,
   
   cout << "c7 =" ;
   for ( c7_Iter = c7.begin( ) ; c7_Iter != c7.end( ) ; c7_Iter++ )
      cout << " " << *c7_Iter;
   cout << endl;
}
  

Requisiti

intestazione: <list>

Spazio dei nomi: deviazione standard

Vedere anche

Riferimenti

list Class

list::list (STL Samples)

Libreria di modelli standard