Поделиться через


list::erase

Удаляет элемент или диапазон элементов в списке из заданных позиций.

iterator erase(
   iterator _Where
);
iterator erase(
   iterator _First,
   iterator _Last
);

Параметры

  • _Where
    Положение элемента необходимо удалить из списка.

  • _First
    Позиция первого элемента удалил из списка.

  • _Last
    Положение непосредственно за последним элементом удалил из списка.

Возвращаемое значение

Двунаправленный итератор, задающий первый элемент оставшиеся за любыми элементами удалил или указатель в конец списка, если такой элемент не существует.

Заметки

Нет переразмещение не происходит, поэтому итераторы и ссылки будут недопустимы только для стертых элементов.

erase никогда не вызывает исключение.

Пример

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

int main( ) 
{
   using namespace std;
   list <int> c1;
   list <int>::iterator Iter;
   
   c1.push_back( 10 );
   c1.push_back( 20 );
   c1.push_back( 30 );
   c1.push_back( 40 );
   c1.push_back( 50 );
   cout << "The initial list is:";
   for ( Iter = c1.begin( ); Iter != c1.end( ); Iter++ )
      cout << " " << *Iter;
   cout << endl;

   c1.erase( c1.begin( ) );
   cout << "After erasing the first element, the list becomes:";
   for ( Iter = c1.begin( ); Iter != c1.end( ); Iter++ )
      cout << " " << *Iter;
   cout << endl;
   Iter = c1.begin( );
   Iter++;
   c1.erase( Iter, c1.end( ) );
   cout << "After erasing all elements but the first, the list becomes: ";
   for (Iter = c1.begin( ); Iter != c1.end( ); Iter++ )
      cout << " " << *Iter;
   cout << endl;
}
  

Требования

заголовок: <list>

std пространство имен:

См. также

Ссылки

list Class

Стандартная библиотека шаблонов