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


Используйте функции vector::erase, vector::empty и vector::p ush_back STL в Visual C++

В этой статье показано, как использовать vector::erase функцию, vector::empty функцию и vector::push_back функции стандартной библиотеки шаблонов (STL) в Visual C++. Информация применяется только к неуправляемого кода Visual C++.

Исходная версия продукта: Visual C++
Исходный номер базы знаний: 158612

Обязательный заголовок

<vector>

Прототипы

template<class _TYPE, class _A>
void vector::push_back(const _TYPE& X);

template<class _TYPE, class _A>
iterator vector::erase(iterator Iterator);

template<class _TYPE, class _A>
iterator vector::erase(iterator First, iterator Last);

template<class _TYPE, class _A>
bool vector::empty() const;

Примечание.

Имена классов и параметров в прототипе могут не совпадать с версией в файле заголовка. Некоторые из них были изменены, чтобы улучшить удобочитаемость.

Description

В примере объявляется пустой вектор целых чисел. Он добавляет в вектор 10 целых чисел, а затем отображает содержимое вектора. Он удаляет шестой элемент с помощью удаления, а затем снова отображает содержимое вектора. Он удаляет остальные элементы с помощью другой формы удаления, а затем снова отображает вектор (теперь пустой). Подпрограмма ShowVector использует пустую функцию, чтобы определить, следует ли создавать содержимое вектора.

Пример кода

В Visual C++ .NET и в Visual C++ параметр /EHsc устанавливается по умолчанию и эквивалентен /GX.

Примечание.

В Visual C++необходимо изменить код, с const ARRAY_SIZE = 10; const int ARRAY_SIZE = 10; которого требуется запустить пример кода.

//////////////////////////////////////////////////////////////////////
// Compile options needed: /GX
// Empty.cpp -- Illustrates the vector::empty and vector::erase
// functions.
// Also demonstrates the vector::push_back function.
// Functions:
// vector::empty - Returns true if vector has no elements.
// vector::erase - Deletes elements from a vector (single & range).
// vector::begin - Returns an iterator to start traversal of the
// vector.
// vector::end - Returns an iterator for the last element of the
// vector.
// vector::push_back - Appends (inserts) an element to the end of a
// vector, allocating memory for it if necessary.
// vector::iterator - Traverses the vector.
// of Microsoft Corporation
// Copyright (c) 1996 Microsoft Corporation. All rights reserved.
//////////////////////////////////////////////////////////////////////
// The debugger can't handle symbols more than 255 characters long.
// STL often creates symbols longer than that.
// When symbols are longer than 255 characters, the warning is disabled.
#pragma warning(disable:4786)

#include <iostream>
#include <vector>

#if _MSC_VER > 1020 // if VC++ version is > 4.2
    using namespace std; // std c++ libs implemented in std
#endif

typedef vector<int, allocator<int> > INTVECTOR;

const ARRAY_SIZE = 10;

void ShowVector(INTVECTOR &theVector);

void main()
{
     // Dynamically allocated vector begins with 0 elements.
     INTVECTOR theVector;

     // Intialize the vector to contain the numbers 0-9.
     for (int cEachItem = 0; cEachItem < ARRAY_SIZE; cEachItem++)
         theVector.push_back(cEachItem);

     // Output the contents of the dynamic vector of integers.
     ShowVector(theVector);

     // Using void iterator erase(iterator Iterator) to
     // delete the 6th element (Index starts with 0).
     theVector.erase(theVector.begin() + 5);

     // Output the contents of the dynamic vector of integers.
     ShowVector(theVector);

     // Using iterator erase(iterator First, iterator Last) to
     // delete a range of elements all at once.
     theVector.erase(theVector.begin(), theVector.end());

     // Show what's left (actually, nothing).
     ShowVector(theVector);
}

// Output the contents of the dynamic vector or display a
// message if the vector is empty.
void ShowVector(INTVECTOR &theVector)
{
     // First see if there's anything in the vector. Quit if so.
     if (theVector.empty())
     {
         cout << endl << "theVector is empty." << endl;
         return;
     }

     // Iterator is used to loop through the vector.
     INTVECTOR::iterator theIterator;

     // Output contents of theVector.
     cout << endl << "theVector [ " ;
     for (theIterator = theVector.begin(); theIterator != theVector.end();
     theIterator++)
     {
         cout << *theIterator;
         if (theIterator != theVector.end()-1) cout << ", ";
         // cosmetics for the output
     }
     cout << " ]" << endl ;
}

Выходные данные программы:

theVector [ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 ]
theVector [ 0, 1, 2, 3, 4, 6, 7, 8, 9 ]
theVector is empty.

Ссылки

vector::empty, vector::erase и vector::push_back