为了教育目的,我尝试实现类似std容器的东西。但我坚持模板函数声明。需要一些帮助,语法在模板类的模板成员函数中返回模板对象
Error: error C2039: 'Begin' : is not a member of 'SinglyLinkedList<T>'.
页眉:
template<class T>
class SinglyLinkedList
{
public:
typedef Iterator<T> Iterator;
SinglyLinkedList();
SinglyLinkedList(const SinglyLinkedList & other);
~SinglyLinkedList();
bool IsEmpty() { return !m_pHead }
void PushFront(T data);
T & Front();
void PopFront();
void Clean();
Iterator<T> Begin(); //Error
// Iterator<T> End();
// Iterator<T> Delete(Iterator<T> it);
private:
Node<T> * m_pHead;
};
CPP文件:
template<class T>
Iterator<T> SinglyLinkedList<T>::Begin()
{
}
编辑:
typedef Iterator<T> Iterator;
只是typedef的,所以我可以使用SinglyLinkedList :: Iterator作为迭代器。我有迭代器类/它看起来像这样:
template<class T>
class Iterator
{
friend SinglyLinkedList<T>;
public:
Iterator() : m_pLinkedList(0), m_pNode(0) {}
~Iterator(){};
private:
Iterator(SinglyLinkedList<T> * pLinkedList, Node<T> * pNode) : m_pLinkedList(pLinkedList), m_pNode(pNode) {}
SinglyLinkedList<T> * GetListPtr() { return m_pLinkedList; }
Node<T> * GetNodePtr() { return m_pNode; }
void SetListPtr(SinglyLinkedList<T> * pList) { m_pLinkedList = pList; }
void SetNodePtr(Node<T> * pNode) { m_pNode = pNode; }
SinglyLinkedList<T> * m_pLinkedList;
Node<T> * m_pNode;
public:
//some overloaded operators
};
只是一个观察,但你需要使用'SinglyLinkedList:迭代SinglyLinkedList ::开始(){}',而不是你有什么 –
只是一个观察,[尝试把在.h文件(HTTP: //stackoverflow.com/questions/495021/why-can-templates-only-be-implemented-in-the-header-file)。 – WhozCraig
@CaptainObvlious只要适当考虑,类型应该没问题。即超类def *可以使用'Iterator',并且类内decl可以使用'Iterator'或者':: Iterator '[见它活](http://ideone.com/feyz99) (或者我误解了你的陈述)。无论如何,我会这样做,只是为了我自己的理智而描述。 –
WhozCraig