我开始学习C++,并作为一个练习决定实现一个简单的LinkedList
类(下面有部分代码)。我有一个关于复制构造函数应该如何实现的问题,以及应该访问原始文件LinkedList
上的最佳方式。LinkedList拷贝构造函数的实现细节
template <typename T>
class LinkedList {
struct Node {
T data;
Node *next;
Node(T t, Node *n) : data(t), next(n) {};
};
public:
LinkedList();
LinkedList(const LinkedList&);
~LinkedList();
//member functions
int size() const; //done
bool empty() const; //done
void append(const T&); //done
void prepend(const T&); //done
void insert(const T&, int i);
bool contains(const T&) const; //done
bool removeOne(const T&); //done
int removeAll(const T&); //done
void clear(); //done
T& last(); //done
const T& last() const; //done
T& first(); //done
const T& first() const; //done
void removeFirst(); //done
T takeFirst(); //done
void removeLast();
T takeLast();
//delete when finished
void print();
//end delete
//operators
bool operator ==(const LinkedList<T> &other) const; //done
bool operator !=(const LinkedList<T> &other) const; //done
LinkedList<T>& operator =(const LinkedList<T> &other); //done
private:
Node* m_head;
Node* m_tail;
int m_size;
};
template<typename T>
LinkedList<T>::LinkedList() : m_head(0), m_tail(0), m_size(0) {
}
...
使我的拷贝构造函数访问原始LinkedList
直接的每个节点上的数据?
template<typename T>
LinkedList<T>::LinkedList(const LinkedList& l) {
m_head = 0;
m_tail = 0;
m_size = 0;
Node *n = l.m_head;
// construct list from given list
while(n) {
append(n->data);
n = n->next;
}
}
或者我应该通过相应的存取访问数据? (我知道我没有定义访问者)。
此外,我打算创建一个自定义迭代器,以便可以遍历LinkedList
。我应该使用复制构造函数来访问每个节点上的数据吗?
另一个问题(完全题外话,我知道),当和/或我们为什么要声明一个指向LinkedList
LinkedList<int> *l = new LinkedList<int>();
,而不是
LinkedList<int> l;
非常感谢! :) – bruno 2010-03-03 20:16:29