c++ - 如何确保销毁父实例成员?

标签 c++ c++11

考虑 C++11 中的这两个类:

class A
{
    ArbitraryClass someInstance;
};

class B : public A
{

};

考虑一下我这样使用 B:

B *foo = new B;
delete foo;

据我了解,A 的隐式析构函数不会在此处调用。

在这种情况下,someInstance 是否仍然被销毁,因为它“关联”为 B 的成员?或者我是否需要在 A 上声明一个虚拟析构函数以自动触发成员的销毁?

最佳答案

如果该类不同于对象的最派生类(在你的情况也是 B)。在您的情况下,这些类是相同的,因此您不需要虚拟析构函数:所有内容都已正确销毁。但是,如果您已将指针类型设置为 A*,那么您需要在 A 中使用一个虚拟析构函数来避免未定义的行为(nasal 守护进程等)。

关于c++ - 如何确保销毁父实例成员?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41917987/

相关文章:

c++ - EXPECT_EQ 和过载错误

c++ - 按类型进行类型安全查找的可变大小异构容器

c++ - cout 是同步的/线程安全的吗?

java - 使用 jni 将位图从 android 相机传递到 C++

c++ - 具有显式类型名称的函数模板

c++ - 引用与信息隐藏 C++

c++ - C++ 'final' 方法注释对类设计有何 promise ?

c++ - 为什么打印语句会改变指针的值?

c++ - 在 hdf5 中使用 std::string 会产生不可读的输出

C++11 多线程,通过引用传递