I have a template class that contains a std::map
that stores pointers to T which refuses to compile:
template <class T>
class Foo
{
public:
// The following line won't compile
std::map<int, T*>::const_iterator begin() const { return items.begin(); }
private:
std::map<int, T*> items;
};
gcc gives me the following error:
error: type 'std::map<int, T*, std::less<int>, std::allocator<std::pair<const int, T*> > >' is not derived from type 'Foo<T>'
Similarly, the following also refuses to compile:
typedef std::map<int, T*>::const_iterator ItemIterator;
However, using a map that doesn't contain the template type works OK, e.g.:
template <class T>
class Foo
{
public:
// This is OK
std::map<int, std::string>::const_iterator begin() const { return items.begin(); }
private:
std::map<int, std::string> items;
};
I assume this is related to templates and begs the question - how can I return a const_iterator
to my map?