爲了教育目的,我嘗試實現類似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