虚拟析构函数-c++
Virtual Destructor - c++
I将基类析构器定义为"Virtual"。例如:-
class Base
{
public:
virtual ~Base()
{
cout << "Calling ~Base()" << endl;
}
};
也在派生类中,例如:例如:-
class Derived: public Base
{
public:
virtual ~Derived()
{
cout << "Calling ~Derived()" << endl;
}
};
我的问题是,在删除基类指向派生类对象的指针时,如何调用两个destuctor。???????谢谢
类的实例在内存中作为"建筑"构建,其中基础是层次结构中最高的类。destructors的调用顺序与构造函数相反。
含义:
子类->子类->类
总是调用析构函数。在你破坏对象(子类)的一部分之后,它派生的类就会被破坏,依此类推
不必从子类中调用"超级"析构函数的原因是必须始终调用析构函数。此外,与可能没有默认构造函数(强制您显式调用超级构造函数)的构造函数相反,析构函数中的情况并非如此。你总是有一个没有参数的析构函数,所以编译器总是可以告诉你要调用"哪个"析构函数(因为没有那么多选项)。
相关文章:
- 什么时候调用组成单元对象的析构函数
- 如果C++类在类方法中具有动态分配,但没有构造函数/析构函数或任何非静态成员,那么它仍然是POD类型吗
- 内联映射初始化的动态atexit析构函数崩溃
- 什么时候调用析构函数
- 优先顺序:智能指针和类析构函数
- C++-明确何时以及如何调用析构函数
- 使用基类指针创建对象时,缺少派生类析构函数
- 在c++中使用向量时,如何调用构造函数和析构函数
- 重载运算符new[]的行为取决于析构函数
- 我需要知道编译器如何在cpp中使用析构函数
- 为什么在使用转换构造函数赋值后调用C++类的析构函数?
- 析构函数调用
- 通过引用传递-为什么要调用这个析构函数
- 对具有动态分配的内存和析构函数的类对象的引用
- 重载 -> shared_ptr 个实例中的箭头运算符<interface>,接口中没有纯虚拟析构函数
- C++成员的析构函数顺序与shared_ptr
- C++ 防止在映射中放置()时调用析构函数
- 在这种情况下显式调用时,std::cout 如何更改析构函数的行为?
- 调用析构函数以释放动态分配的内存
- 不命名构造函数和析构函数上的类型错误