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?
Use typename:
typename std::map<int, T*>::const_iterator begin() const ...
When this is first passed by the compiler, it doesn't know what T is. Thus, it also doesn't know wether const_iterator is actually a type or not.
Such dependent names (dependent on a template parameter) are assumed to
typenametemplate.If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With