C 模板:创建与现有对象相同的类型对象
c++ templates: create an object of a typename same as of an existing object
我正在使用C 中的模板类。我创建一个类的对象如下:
Node<int> *rootNode = (Node<int> *) malloc(sizeof(Node<int>));
现在,我在节点中插入了一些条目。看到节点已满后,我希望代码可以创建一个与root节点相同的打字名称并存储所需数据的新节点。以下是我插入的方法:
template <typename T>
RC Node<T>::Insert(void *key)
{
if(space() > 0) { // check if current node has ample space
// add data in the current node
}
else
{
siblingNode = new Node<T>();
if (this->Split(siblingNode, key)) {
if (siblingNode != NULL) {
siblingNode.display();
}
}
}
}
}
我尝试显示使用
创建的新节点siblingnode.display()
方法,但它给了我汇编错误
request for member ‘display’ in ‘siblingNode’, which is of non-class type ‘Node<int>*’
如何确保siblingNode与调用插入函数的节点的输入键相同?
siblingNode
是一个指针,因此您需要使用指针成员删除操作员:
siblingNode->display()
错误是告诉您您要提出的类型是指针,而不是您需要与Node<T>
相同的打字机。
相关文章:
- 在 C++ 中将一个模板类型的对象类型转换为另一个模板类型
- 了解 Python 中的对象类型
- 具有纯虚函数和指针数组对象类型的父类的指针数组
- 调用的对象类型 'double' 不是 report() 函数的函数或函数指针
- 基准、值、值类型、对象和对象类型(C++)
- JNI 如何将 Java 对象数组传递给相同对象类型的 C++ 数组
- 在构造过程中更改的对象类型
- 如何构建程序以避免查询对象类型?
- 如何使用Dynamic_cast获得对象类型
- 什么更有效率?在重载函数中或通过在基类函数中检查对象类型来实现
- static_cast实际上不是对象类型的类型是未定义的行为吗?
- 为什么 std::variant 不能容纳数组对象类型,而联合可以?
- 为什么类型转换对象不会更改其地址?有关对象类型的信息存储在哪里?
- 类返回对象类型,但如何返回和检查 null
- 是否可以在辅助功能中概括对象类型
- 表达式必须在C 中具有指针对象类型
- 下标需要数组或指针类型表达式必须具有指针对象类型
- 当将对象传递给具有参数作为引用类型的函数以及当其类对象类型时,会得到不同的输出
- 如何在运行时指定对象类型
- 我可以获取在重载的新运算符中使用新运算符的对象类型吗?