Compartir a través de


list::splice

Quita los elementos de la lista de argumentos y los inserta en la lista de destinos.

void splice(
   iterator _Where,
   list<Type, Allocator>& _Right
);
void splice(
   iterator _Where,
   list<Type, Allocator>& _Right,
   iterator _First
);
void splice(
   iterator _Where,
   list<Type, Allocator>& _Right,
   iterator _First,
   iterator _Last
);

Parámetros

  • _Where
    La posición en el destino enumerado antes de que los elementos de la lista de argumentos deben ser incrustados.

  • _Right
    La lista de argumentos que debe incrustar en la lista de destinos.

  • _First
    El primer elemento del intervalo que se va a insertar en la lista de argumentos.

  • _Last
    El primer elemento más allá del intervalo que se va a insertar en la lista de argumentos.

Comentarios

La primera función miembro inserta todos los elementos de la lista de argumentos antes del elemento situado en _Where en la lista de destinos.también quita todos los elementos de la lista de argumentos.

La segunda función miembro quita el elemento indicada por _First en la lista de argumentos y se inserta antes del elemento en el destino enumere resaltado por a _Where.

La tercera función miembro inserta el intervalo designado por [_First, _Last) de la lista de argumentos antes del elemento en el destino enumere resaltado por a _Where.También quita el intervalo incrustado de la lista de argumentos.

En todos los casos, los iteradores o las referencias que señalan en los elementos unidos dejan de ser válidos.

Ejemplo

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

int main( )
{
   using namespace std;
   list <int> c1, c2, c3, c4;
   list <int>::iterator c1_Iter, c2_Iter, w_Iter, f_Iter, l_Iter;
   
   c1.push_back( 10 );
   c1.push_back( 11 );
   c2.push_back( 12 );
   c2.push_back( 20 );
   c2.push_back( 21 );
   c3.push_back( 30 );
   c3.push_back( 31 );
   c4.push_back( 40 );
   c4.push_back( 41 );
   c4.push_back( 42 );

   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;

   w_Iter = c2.begin( );
   w_Iter++;
   c2.splice( w_Iter,c1 );
   cout << "After splicing c1 into c2: c2 =";
   for ( c2_Iter = c2.begin( ); c2_Iter != c2.end( ); c2_Iter++ )
      cout << " " << *c2_Iter;
   cout << endl;

   f_Iter = c3.begin( );
   c2.splice( w_Iter,c3, f_Iter );
   cout << "After splicing the first element of c3 into c2: c2 =";
   for ( c2_Iter = c2.begin( ); c2_Iter != c2.end( ); c2_Iter++ )
      cout << " " << *c2_Iter;
   cout << endl;

   f_Iter = c4.begin( );
   l_Iter = c4.end( );
   l_Iter--;
   c2.splice( w_Iter,c4, f_Iter, l_Iter );
   cout << "After splicing a range of c4 into c2: c2 =";
   for ( c2_Iter = c2.begin( ); c2_Iter != c2.end( ); c2_Iter++ )
      cout << " " << *c2_Iter;
   cout << endl;
}
  

Requisitos

encabezado: <lista>

espacio de nombres: std

Vea también

Referencia

list Class

Biblioteca de plantillas estándar