遗产选定的功能
Heritage selected functions
EI正在做一个关于数据结构类的项目,它必须实现不同类型的结构。
如数组、链接、双链接、圆形等...
这些结构中的每一个都使用一种类型,即堆栈、队列或列表。
例:
VectorStructure.h
template<typename T>
class VectorStructure{
public:
int addOnPosition(T element, int pos);
int addOnBeginning(T element);
int add(T element);
int addElementOrdered(T element);
T removeFromPos(int pos);
T removeFromBeginning();
T remove();
T removeElement(T element);
}
这些类型的每个实现都包含与其他实现完全相同的代码。
堆栈:是一个后进先出结构,只使用方法:add(T element( 和 remove((;
队列:是一个FIFO结构,只使用方法:add(T element(和removeFromBeginning((;
List:是一个动态数组,可以使用任何这些方法和一些额外的方法。
我的想法是:在基类上实现所有这些函数,并使这些类型仅使用基类所需的方法。我以为我可以使用继承,但是堆栈可以从基类访问不允许的函数,因为它是"子"还认为我可以使用抽象类,但是,为了编译,我应该实现抽象类中包含的所有方法。
类型(它们只是示例,还有一些其他方法在所有类型上都是相同的(:
列表.h
template<typename T>
class List{
public:
int addOnPosition(T element, int pos);
int addOnBeginning(T element);
int add(T element);
int addElementOrdered(T element);
T removeFromPos(int pos);
T removeFromBeginning();
T remove();
T removeElement(T element);
Stack.h
template<typename T>
class Stack{
public:
int add(T element);
T remove();
队列.h
template<typename T>
class Queue{
public:
int add(T element);
T removeFromBeginning();
有没有办法实现这个想法?
我不确定我是否正确理解您的问题,但我想您希望避免代码重复 - 如何将底层容器类型作为模板类型名传递,就像 STL 对容器适配器所做的那样std::stack
?
template<typename T> struct BaseContainer {
void push_front(T);
void push_back(T);
T pop_front();
T pop_back();
};
template<typename T, typename TUnderlying = BaseContainer> class Stack {
TUnderlying baseContainer;
public:
void push(T item) { baseContainer.push_back(item); }
T pop() { return baseContainer.pop_back(); }
};
template<typename T, typename TUnderlying = BaseContainer> class Queue {
TUnderlying baseContainer;
public:
void enqueue(T item) { baseContainer.push_back(item); }
T dequeue() { return baseContainer.pop_front(); }
};
相关文章:
- 在执行其他功能的同时播放动画(LED矩阵和Arduino/ESP8266)
- 多态性和功能结合
- 带内存和隔离功能的SQLite
- 在CMakeLists.txt的安装功能中使用.cmake文件有什么用
- 类模板的成员功能的定义在单独的TU中完全专业化
- 有没有一种方法可以创建一个带有哈希表的数据库,该哈希表具有恒定时间查找功能
- 如何在C++中获得"静态纯虚拟"功能?
- 两个文件使用彼此的功能-如何解决
- 我应该实现右值推送功能吗?我应该使用std::move吗
- QML按钮点击功能执行顺序
- 无法理解此 return 语句的功能,没有它就会发生运行时错误
- 有没有可能有一个只有ADL才能找到的非好友功能
- 功能样式转换从 'int' 到 'ItemType' 的匹配转换
- 文件系统:复制功能的速度秘诀是什么
- 在用于格式4的arm模拟器中实现功能时的一个问题
- 如何在Directwrite中获得给定字体的可用OpenType功能
- 对可变参数使用声明.如何选择正确的功能
- 询问在设计我的手臂模拟器功能表示格式1
- 功能原型的目的
- 遗产选定的功能