删除时发生错误:表达式必须是指向完整对象类型的指针
问题描述:
我想要删除嵌套在数组中另一个类中的类。我得到一个智能感知错误,指出:删除时发生错误:表达式必须是指向完整对象类型的指针
“表达式必须是一个指向一个完整的对象类型”
我试图通过创建一个指向对象和可视化的参考删除它的另一种方式工作室出错,并给我一个DLL错误,基本上说明调试符号不加载。
以下是代码片段 -
graphl.cpp
GraphL::~GraphL()
{
NodeData* rmND; // remove NodeData
GraphNode* rmGN; // remove GraphNode
for (int i = 1; i <= size; i++)
{
deleteEdges(adjList[i]->edgeHead);
rmGN = adjList[i];
delete rmGN->data; //////////////// <-- error here
rmGN->edgeHead = nullptr;
delete rmGN;
}
delete[] adjList;
}
graphl.h
class GraphL {
public:
GraphL();
~GraphL();
void buildGraph(istream& infile);
void depthFirstSearch();
//void displayGraph();
private:
struct EdgeNode {
int adjGraphNode;
EdgeNode* nextEdge;
EdgeNode() : adjGraphNode(0), nextEdge(nullptr) {};
};
struct GraphNode {
EdgeNode* edgeHead;
NodeData data;
bool visited;
GraphNode() : edgeHead(nullptr), visited(false) {};
};
static const int MAXNODES = 6;
GraphNode* adjList[MAXNODES]{}; // adjacency list
//void makeEmpty();
int size;
bool insertEdge(int from, int to);
void dfsHelper(int search);
void deleteEdges(EdgeNode* remove);
};
nodedata.h
class NodeData {
friend ostream & operator<<(ostream &, const NodeData &);
public:
NodeData(); // default constructor, data is set to an empty string
~NodeData();
NodeData(const string &); // data is set equal to parameter
NodeData(const NodeData &); // copy constructor
NodeData& operator=(const NodeData &);
// set class data from data file
// returns true if the data is set, false when bad data, i.e., is eof
bool setData(istream&);
bool operator==(const NodeData &) const;
bool operator!=(const NodeData &) const;
bool operator<(const NodeData &) const;
bool operator>(const NodeData &) const;
bool operator<=(const NodeData &) const;
bool operator>=(const NodeData &) const;
private:
string data;
};
如果我试图rmND = rmGN-> data;删除rmND; Visual Studio给了我一个wntdll.pdb未加载的错误。如何正确删除该对象?任何帮助表示赞赏!谢谢。
答
您尝试删除的项目不是指向动态内存的指针,它是对象的本地对象,因此必须删除父对象才能清除内存。
更准确地说,您只能删除使用new关键字显式创建的一段内存。
无需删除对象。
偏离主题,但数组下标从0到N-1,而不是1到N. – chris
0为NULL。它未被使用,因此没有任何事情发生在它。对象从1-N插入。 – endanegered
@endanegered - * 0为NULL。它的未使用,因此没有发生任何事情* - 我看到太多的程序失败,因为他们试图伪造基于1的阵列。无论是'0'元素是否被偶然使用,或者索引在数组末尾都是一次性的。只需以'0'开始你的数组。 – PaulMcKenzie