固定大小的列表
Fixed size list
本文关键字:列表 更新时间:2023-10-16
我正在使用固定数组编写FixedSizeList类。我有一个固定大小的模板参数的问题,我试图了解如果我的解决方案是正确的,甚至我如何解决我的问题。
基本上,这是我的类的骨架:
#pragma once
template <typename T, unsigned int N>
class SListFixed
{
public:
SListFixed();
private:
template <typename T>
struct Node
{
Node(T value)
:element(value), nextElement(0)
{
}
T element;
int nextElement;
};
Node m_data[N];
int m_head;
int m_tail;
size_t m_elementCounter;
};
第一个问题是关于这个结构的正确性。然后我想了解为什么这段代码不能编译。我应该把m_data作为一个指针并在堆栈上分配吗?
谢谢。
要编译它,请更改
Node m_data[N];
Node<T> m_data[N];
因为Node
毕竟是一个模板类
也就是说,简单地执行Oli所说的并从Node
的定义中删除template <typename T>
也可以工作,因为T
是从FixedSizeList
实例化中已知的。我建议这样做,因为Node
的类型不能与FixedSizeList
的类型不同。
list根据定义是可变大小的容器。为什么不直接使用数组类呢?
很难说这是否是一个好的解决方案,但从表面上看,它看起来不错(尽管存在编译器错误)。虽然我不太确定为什么你想要一个固定大小的列表;列表的全部意义不就是你可以动态地调整它的大小吗?为什么不只是一个数组/向量?
至于你的编译问题,你不需要内部类的template <typename T>
;这已经是模板的一部分,并且T
是已知的。此外,您没有Node
的默认构造函数,因此Node m_data[N]
将无法编译。
相关文章:
- Pybind11:将元组列表从Python传递到C++
- 从链接列表c++中删除一个项目
- 如何(从固定列表中)选择一个数字序列,该序列将与目标数字相加
- C++如何通过用户输入删除列表元素
- 读取文件的最后一行并输入到链接列表时出错
- 复制列表初始化的隐式转换的等级是多少
- LNK2038、MSVS2017 MAGMA的原因列表
- 不能在初始值设定项列表中将非常量表达式从类型 'int' 缩小到'unsigned long long'
- 没有为自己的结构调用列表推回方法
- 使用简单类型列表实现的指数编译时间.为什么
- 一对向量构造函数:初始值设定项列表与显式构造
- 标准是否使用多余的大括号(例如 T{{{10}}})定义列表初始化?
- 通过for循环使用用户输入填充列表
- C++:如何使函数只返回作为列表一部分的字符串
- 概念中的cv限定符需要表达式参数列表
- 下面是我为检测链接列表中的循环而制作的代码
- 建议在运行时将带有类实例的列表从c++导入qml
- 如何维护资源管理器项目视图中当前可见的项目列表
- 在卡萨布兰卡形成编码参数的列表
- 在没有参数列表的情况下使用模板名称"Event"无效,模板问题