list::splice

Entfernt Elemente aus der Argumentliste und fügt sie in die Zielliste ein.

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

Parameter

  • _Where
    Die Position in der Zielliste, vor der die Elemente der Argumentliste eingefügt werden sollen.

  • _Right
    Die Argumentliste, die in die Zielliste eingefügt werden soll.

  • _First
    Das erste Element im aus der Argumentliste eingefügt werden, Bereich.

  • _Last
    Das erste Element über dem aus der Argumentliste einzufügende Bereich hinaus.

Hinweise

Die erste Memberfunktion fügt alle Elemente in der Argumentliste vor dem Element ein, das bei _Where in der Zielliste befindet.Sie entfernen zudem alle Elemente aus der Argumentliste.

Die zweite Memberfunktion entfernt das Element, das auf durch _First in der Argumentliste dargestellt wird und fügt es ein, bevor das Element in der Zielliste auf durch _Where auf.

Die dritte Memberfunktion fügt den Bereich ein, der von festgelegt wird _First[, _Last) aus der Argumentliste, bevor das Element in der Zielliste auf durch _Where auf.Sie entfernen zudem den Bereich, der aus der Argumentliste eingefügt wird.

In allen Fällen werden nur Iteratoren oder Verweise, die an verbundenen Elementen zeigen, ungültig.

Beispiel

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

Anforderungen

Header: <list>

Namespace: std

Siehe auch

Referenz

list Class

Standardvorlagenbibliothek