如何检查类数组的元素是否为空?[C++]
How do I check if an element of an array of classes is empty? [c++]
对于我的最新作业,我需要创建一个哈希表来容纳股票,这些股票被封装在一个类中。为了避免碰撞,我需要使用线性探测。但是,我遇到的问题;是我无法测试数组的元素(即哈希表)是否为空。
下面是从多个文件聚合的一些代码,但这只是为了让您了解发生了什么。
class Stock{
friend class HashMap
}
class HashMap{
bool get() //this function is used for putting new stocks into the table
private:
struct Slot {
Stock slotStock;
}
Slot *slots;
}
在 get() 函数中
while(slots[index] != NULL)
这给出了一个错误:没有运算符 "!=" 匹配这些操作数 哈希映射::插槽 != int
我有什么替代方法来检查插槽是否为空?
数组是动态分配的。
编辑:当我初始化数组时,它是使用默认构造函数为数组的每个元素创建一个对象,还是将元素留空?
如果你有一个类型为 X
的对象数组,则没有一个插槽是"空的"。它们都包含一个类型为 X
的对象。若要表示空对象,它必须是存储在数组中的类型的可能状态。 例如,您可以有 boost::optional<Slot>
或 std::unique_ptr<Slot>
。否则,可以将状态直接编码到 Slot
类中(例如,使用 bool 成员)。
您要做的是存储一个 Stock 指针数组,而您当前正在存储一个 Slot 对象数组。 为了使自己更轻松,您可以使用向量来存储指针。
您的后备数据结构如下所示:
std::vector< Stock* > vecStocks;
向量中的每个项目都是一个"槽",除非您打算存储一些关于股票的元数据,否则您不需要 Slot 类。
要检查您在矢量的任何插槽中是否有库存,请将矢量项与 NULL 进行比较,如下所示:
if (vecStocks[index] == NULL)
这种方法有一个积极的副作用,即不需要预先分配 X 数量的 Stock 对象,其中 X 是哈希图的大小(可能是一个非常大的数字,具体取决于您希望碰撞的频率)。
相关文章:
- 在提升multi_index容器中,是否定义了"default index"?
- 在C++STL中是否有Polyval(Matlab函数)等价物?
- 检查输入是否不是整数或数字
- 是否可以初始化不可复制类型的成员变量(或基类)
- 在C++中,是否可以基于给定的标识符创建基类的新实例,反之亦然
- 是否可以通过C++扩展强制多个python进程共享同一内存
- 此代码是否违反一个定义规则
- 是否需要删除包含对象的"pair"?
- 是否可以从int转换为enum类类型
- 无论条件是否为true,if总是在c++中执行
- 如何找到大小'x'数组是否完全填充,在C++?
- 检查值是否在集合p1和p2中,但不在p3中
- 是否可以在编译时初始化数组,以便在运行时不会花费时间?
- 检查 std::shared_ptr<> 的当前底层类型是否为 T
- 在c++中检查长方体是否尽可能快地重叠(无迭代)
- GL_SHADERSTORAGE_BUFFER位置是否与其他着色器位置冲突
- 子目录是否继承属性,例如add_definitions,include_directories和父Cmakelist.t
- 标准是否使用多余的大括号(例如 T{{{10}}})定义列表初始化?
- C/C++预处理器是否可以检测一些编译器选项
- 是否可以用"iostream"包装现有的TCP/OOpenSSL会话