C++ "Pure Virtual Function Being Called"失败
C++ Failing on "Pure Virtual Function Being Called"
我正在编写一些代码以从AVL树中删除。下面是一个有助于删除的示例函数:
int AVL::getLargestAndTrim(Node*& currentNode, Node* parentNode) {
if (currentNode->right == nullptr) {
int returnData = currentNode->data;
parentNode->right = currentNode->left;
delete currentNode;
return returnData;
}
else {
Node* rightChild = currentNode->right;
return this->getLargestAndTrim(currentNode->right, currentNode);
}
}
该代码不断失败,消息"纯虚拟方法调用终止调用而不出现活动异常"。
现在,如果我更换行
return this->getLargestAndTrim(currentNode->right, currentNode);
跟
return this->getLargestAndTrim(rightChild, currentNode);
它工作正常。如何?
编辑:节点类定义为:
class Node {
public:
Node() {}
Node(int data) : data(data) {}
~Node() {}
private:
int data = 0;
Node* left = nullptr;
Node* right = nullptr;
int height = 0;
friend class AVL;
};
你的序列
parentNode->right = currentNode->left;
delete currentNode;
是错误的。 因为currentNode
是对parentNode->right
的引用,所以当你进行赋值时,它会改变currentNode
的值,然后你删除了currentNode->left
中的内容,同时在树中有一个悬空的指针指向已删除的数据。
稍后,当为已删除的对象调用析构函数时,您将收到错误。
相关文章:
- 如果没有malloc,链表实现将失败
- 模板参数替换失败,并且未完成隐式转换
- 具有默认模板参数的多态类的模板推导失败
- 视图中的参数推导失败:take_while
- 链接到自行创建的dll失败
- 带有特殊路径部分的"std::filesystem::weakly_canonical"失败
- GetShortPathName在网络驱动器上使用中文文件夹时失败
- gcc和c++17的过载解析失败
- 为什么使用 P/Invoke 调用 dll 时,某些计算机中的 LoadLibrary 失败?
- 在WSL:configure_file上对config_file的每次调用都失败:配置文件时出现问题
- 使用 GCC 卸载的 OpenMP 卸载失败,并出现"Ptx assembly aborted due to errors"
- 使用cmake从源代码构建MySQL连接器/C++失败(与以前的声明冲突)
- 链接阶段在Ubuntu上失败,但在MacOS上失败
- 从父数组测试用例构造二叉树失败
- LibGit2 SSH身份验证失败
- 如何让LLDB在成功时退出,在失败时等待
- VS2017,C++包含目录与附加包含目录,子文件夹包含失败-但为什么
- 生成MRPT库时cmake配置失败
- 为什么除非添加括号,否则构造函数上的模板替换会失败?
- C++ "Pure Virtual Function Being Called"失败