是接口所需的虚析构函数,如果总是将其存储在shared_ptr中
Is a virtual destructor needed for your Interface, if you always store it in a shared_ptr?
由于boost::/std::shared_ptr
具有类型擦除其删除器的优势,因此您可以做一些很好的事情,例如
#include <memory>
typedef std::shared_ptr<void> gc_ptr;
int main(){
gc_ptr p1 = new int(42);
gc_ptr p2 = new float(3.14159);
gc_ptr p3 = new char('o');
}
由于保存了正确的删除器,这将正确地删除所有指针。
如果你确保你的接口的每个实现总是用shared_ptr<Interface>
(或make_shared<Interface>
)创建,你真的需要virtual
析构函数吗?我将声明它virtual
无论如何,但我只是想知道,因为shared_ptr
将始终删除它初始化的类型(除非给出另一个自定义删除器)。
对于要派生的类,我仍然会遵循通用规则:
提供公共虚析构函数或受保护的非虚析构函数
原因是您不能控制所有的使用,并且这个简单的规则意味着如果您试图通过层次结构中的错误级别delete
,编译器将标记。考虑shared_ptr
不保证调用适当的析构函数,只保证调用用作实参的静态类型的析构函数:
base* foo();
shared_ptr<base> p( foo() );
如果base
有一个公共非虚析构函数,并且foo
返回的类型派生自base
,则shared_ptr
将无法调用正确的析构函数。如果base
的析构函数是虚的,则一切正常,如果它是受保护的,则编译器会告诉您那里有错误。
相关文章:
- 将字符串存储在c++中的稳定内存中
- std::原子加载和存储都需要吗
- C++:将控制台输出存储在宏中更好吗
- 使用QProcess执行命令,并将结果存储在QStringList中
- 访问存储在向量C++中的结构的多态成员
- 如何从存储在std::映射中的std::集中删除元素
- 存储模板类型以强制转换回派生<T>
- 类型总是使用其大小存储在内存中吗
- 当字符串存储在变量中时,如何将字符串转换为wchar_t
- 使用无符号字符数组有效存储内存
- 如何在cpp.中使用协议缓冲区存储大缓冲区/数组(char/int)
- 使用 pqxx 将 std::vector 存储在 postgresql 中,并从数据库中检索它
- 带结构的二维矢量:如何存储元素
- 添加存储在向量中的大整数的函数出现问题
- 从文件中读取多个字节,并将它们存储在C++中进行比较
- 在std::vector上存储带有模板的类实例
- 谷歌测试中的期望值存储在哪里
- 为什么C中的通用链表中存储的数据已损坏
- 在c++中获取两个大int,并将它们存储在数组中
- 在reactor中存储eventHandlers的最佳方式是什么