我开始学习 C++,并作为练习决定实现一个简单的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;