如何使用多态性填充链接列表
How do I populate a linked list using polymorphism?
我已经设置了一个由列表类和节点类组成的链接列表,如何用不同类的节点填充列表类?
这些元素必须是指针(最好是智能)以避免切片。那是我看到的单一限制。
YourList<std::unique_ptr<BaseClass> > myList;
myList.add(new DerivedClassA);
myList.add(new DerivedClassB);
如何用不同类的节点填充列表类?(现在编译时间多态性,将不同的对象放入不同的列表中)
我认为您当前有类似的东西:
class Node {
public:
Node* next;
int datum;
int& GetDatum() { return datum; }
};
class List {
public:
Node* head;
int Count();
};
int List::Count() { /* compute length */; return length; }
int main () { List a; List b; }
我想您还有其他更有用的成员功能,但是这些足以证明这一点。
您可以将上述代码转换为使用模板使用编译时间多态性:
#include <string>
template<class T>
class Node {
public:
Node* next;
T datum;
T& GetDatum() { return datum; }
};
template<class T>
class List {
public:
Node<T>* head;
int Count();
};
template<class T>
int List<T>::Count() { /*...*/; return length; }
int main () { List<int> a; List<std::string> b; return a.Count(); }
相关文章:
- 从链接列表c++中删除一个项目
- 读取文件的最后一行并输入到链接列表时出错
- 下面是我为检测链接列表中的循环而制作的代码
- 有人能帮我处理这个链接列表吗?C++
- C++ 创建包含链表和字符串的对象的链接列表时出错
- 你能检查一下为什么在这个代码中从链接列表中删除项目不起作用吗
- 为什么它只打印双链接列表的第一个值,而我的程序却崩溃了
- 链接列表运算符重载没有打印出我想要的内容
- 链接列表在 cpp 中包含不同的对象类
- 创建一个棋盘格或"Interweave"两个链接列表。IE 更改两个链表的指针
- 如何在构建链接列表时调整头、尾指针
- Shared_ptr双链接列表内存泄漏
- 为什么每当我尝试运行此链接列表删除功能时都会收到分段错误错误?
- 在链接列表中查找元素 - C++
- 删除链接列表中剩余的最后一个节点
- 只有我的"链接列表"中的第一个节点正在打印
- 避免在使用链接列表从 deque 中删除最后一个节点时出现内存泄漏
- C++ 分段错误:11 错误,同时编码将两个数字相加的链接列表
- 如何在C / C++中正确实现链接列表而不会使程序崩溃
- 将元素插入链接列表