нет функции-члена для вызова "стереть"
вот код, который вызывает ошибку:
фабрики.h:
#include <string>
#include <map>
namespace BaseSubsystems
{
    template <class T>
    class CFactory
    {
    protected:
        typedef T (*FunctionPointer)();
        typedef std::pair<std::string,FunctionPointer> TStringFunctionPointerPair;
        typedef std::map<std::string,FunctionPointer> TFunctionPointerMap;
        TFunctionPointerMap _table;
    public:
        CFactory () {}
        virtual ~CFactory();
    }; // class CFactory
    template <class T> 
    inline CFactory<T>::~CFactory()
    {
        TFunctionPointerMap::const_iterator it = _table.begin();
        TFunctionPointerMap::const_iterator it2;
        while( it != _table.end() )
        {
            it2 = it;
            it++;
            _table.erase(it2);
        }
    } // ~CFactory
}
и ошибка, которую я получаю:
error: no matching member function for call to 'erase' [3]
                         _table.erase(it2);
                         ~~~~~~~^~~~~
какие-либо советы? Спасибо.
3 ответов
вот подпись map::erase в C++98:
void erase( iterator position );
эта функция принимает iterator но вы проходите const_iterator. Вот почему код не компилируется.
как это исправить?
в C++11 это даже не проблема, поэтому ее не нужно исправлять. Это потому, что в C++11 map::erase функция имеет следующую подпись и, таким образом, принимает const_iterator.
iterator erase( const_iterator position );
если вы не можете использовать новый стандарт, вам придется изменить переменные на .
смотрите, что говорит мастер:
шотландец Мейерс в эффективном STL
пункт 26. Предпочитаю итератор константный итератор, итератор reverse_iterator, и const_reverse_iterator. Хотя контейнеры поддерживают четыре типа итераторов, один из этих типов имеет права не имеют. Этот тип является iterator, iterator является специальным.
typedef deque<int> IntDeque; //STL container and
typedef lntDeque::iterator Iter; // iterator types are easier
typedef lntDeque::const_iterator ConstIter; // to work with if you
// use some typedefs
Iter i;
ConstIter ci;
… //make i and ci point into
// the same container
if (i == ci ) ... //compare an iterator
// and a const_iterator
пункт 27. Используйте distance и advance для преобразования const_iterators контейнера в итераторы.
typedef deque<int> IntDeque; //convenience typedefs
typedef lntDeque::iterator Iter;
typedef lntDeque::const_iterator ConstIter;
ConstIter ci; // ci is a const_iterator
…
Iter i(ci); // error! no implicit conversion from
// const_iterator to iterator
Iter i(const_cast<Iter>(ci)); // still an error! can't cast a
// const_iterator to an iterator
что работает заранее и расстояние
typedef deque<int> IntDeque; //as before
typedef IntDeque::iterator Iter;
typedef IntDeque::const_iterator ConstIter;
IntDeque d;
ConstIter ci;
… // make ci point into d
Iter i(d.begin()); // initialize i to d.begin()
Advance(i, distance(i, ci)) //move i up to where ci is
// (but see below for why this must
// be tweaked before it will compile)
