Partager via


list::splice

Supprime les éléments de la liste d'arguments et les insère dans la liste cible.

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
);

Paramètres

  • _Where
    Position dans la liste cible avant laquelle les éléments de la liste d'arguments doivent être insérés.

  • _Right
    La liste d'arguments qui doit être insérée dans la liste cible.

  • _First
    Le premier élément de la plage à insérer dans la liste d'arguments.

  • _Last
    Le premier élément au delà de la plage à insérer dans la liste d'arguments.

Notes

La première fonction membre insère tous les éléments de la liste d'arguments avant l'élément situé à _Where dans la liste cible.Elle supprime tous les éléments de la liste d'arguments.

La deuxième fonction membre supprime l'élément globale pointe vers _First dans la liste d'arguments et l'insère avant l'élément dans la liste des cibles soit globale pointe vers _Where.

La troisième fonction membre insère l'intervalle désigné par [_First, _Last) de la liste d'arguments avant l'élément dans la liste des cibles soit globale pointe vers _Where.Elle supprime également l'intervalle inséré dans la liste d'arguments.

Dans tous les cas, seules les itérateurs ou les références qui pointent vers les éléments épissés deviennent non valides.

Exemple

// 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;
}
  

Configuration requise

en-tête : <list>

l'espace de noms : DST

Voir aussi

Référence

list Class

Modèles Standard