链表析构函数(c++)
Linked list destructor (C++)
我有循环链表,我有调用析构函数的问题。
这是list的结构:
struct LList {
LList(const string & name) : Next(NULL), Name(name) {
}
LList * Next;
string Name;
};
这是我的代码:
~Class (){
LList * tmp1= First;
LList * tmp2;
while(tmp1){
tmp2=tmp1->Next;
delete tmp1;
tmp1=tmp2;
}
}
我试图使用valgrind,但我不确定它的结果。谁能告诉我我做错了什么?
问题是主函数结束后出现段故障。
如果列表是循环的,那么析构函数将是一个无限循环(或者是俄罗斯轮盘赌)。
它应该有点像:
~Class() {
// break the circle
LList cur = First;
Llist nxt = head->Next;
if (nxt) cur->Next = 0;
cur = nxt;
// walk through the list and delete nodes
while (cur) {
nxt = cur->Next;
delete cur;
cur = nxt;
}
}
我认为你应该在析构函数中这样写:
delete Next;
你现在做的是错误的,因为:
- 在读取tmp1->next 之前不检查tmp1是否为null
- 如果我遵循你正在尝试做的,在第一个元素上调用析构函数将在所有接下来的元素上调用delete。问题是,每次在其中一个对象上调用delete时,它的析构函数也会在所有下一个对象上调用delete,所以您将尝试删除不再存在的对象。
相关文章:
- 什么时候调用组成单元对象的析构函数
- 如果C++类在类方法中具有动态分配,但没有构造函数/析构函数或任何非静态成员,那么它仍然是POD类型吗
- 内联映射初始化的动态atexit析构函数崩溃
- 什么时候调用析构函数
- 优先顺序:智能指针和类析构函数
- C++-明确何时以及如何调用析构函数
- 使用基类指针创建对象时,缺少派生类析构函数
- 在c++中使用向量时,如何调用构造函数和析构函数
- 重载运算符new[]的行为取决于析构函数
- 我需要知道编译器如何在cpp中使用析构函数
- 为什么在使用转换构造函数赋值后调用C++类的析构函数?
- 析构函数调用
- 通过引用传递-为什么要调用这个析构函数
- 对具有动态分配的内存和析构函数的类对象的引用
- 重载 -> shared_ptr 个实例中的箭头运算符<interface>,接口中没有纯虚拟析构函数
- C++成员的析构函数顺序与shared_ptr
- C++ 防止在映射中放置()时调用析构函数
- 在这种情况下显式调用时,std::cout 如何更改析构函数的行为?
- 调用析构函数以释放动态分配的内存
- 不命名构造函数和析构函数上的类型错误