这是我的代码:
template <class a, class b>
class LinkedListIter{
public:
LinkedListIter(b* iterable){
this->iterable = iterable;
this->head = this->iterable->head;
this->curr = this->iterable->curr;
this->iter_pos = 0;
};
void operator++(int dummy){
this->iter_pos++;
};
friend std::ostream& operator<< (std::ostream& o, LinkedListIter const& lli);
private:
a* head;
a* curr;
b* iterable;
int iter_pos; //The current position if the iterator
};
std::ostream& operator<< (std::ostream& o, LinkedListIter const& lli){
return o << lli.get(lli.iter_pos);
}
我在声明std::ostream& operator<< (std::ostream& o, LinkedListIter const& lli)
的行上收到错误,说LinkedListIter没有命名类型。为什么会这样?
答案 0 :(得分:5)
LinkedListIter
是一个类模板,而不是一个类。因此,您的运营商也需要成为模板。
template<typename a, typename b>
std::ostream& operator<< (std::ostream& o, LinkedListIter<a,b> const & lli){
...
答案 1 :(得分:1)
#include <iostream>
template <class a, class b>
class LinkedListIter;
template <class a, class b>
std::ostream& operator<< (std::ostream& o, LinkedListIter<a, b> const& lli);
template <class a, class b>
class LinkedListIter{
public:
LinkedListIter(b* iterable) {
this->iterable = iterable;
this->head = this->iterable->head;
this->curr = this->iterable->curr;
this->iter_pos = 0;
};
void operator++(int dummy) {
this->iter_pos++;
};
friend std::ostream& operator<< <a, b> (std::ostream& o, LinkedListIter const& lli);
private:
a* head;
a* curr;
b* iterable;
int iter_pos; //The current position if the iterator
};
template <class a, class b>
std::ostream& operator<< (std::ostream& o, LinkedListIter<a, b> const& lli) {
return o << lli.get(lli.iter_pos);
}
这段代码可以很好地编译,希望得到帮助。