使用delete调用析构函数
calling destructor using delete
执行以下操作正确吗:
MyClass mc1(1, 1);
MyClass* pmc1 = &mc1;
delete pmc1;
我在一个代码示例中看到了它。我想我们可以在指向堆上分配的对象的指针上调用delete,但这个指针指向堆栈上的一个对象,不是吗?有人能解释一下吗?
否。您永远不应该在指向尚未使用new
创建的对象的指针上调用delete
。这是未定义的行为。
C++标准n3337§5.3.5/2删除
(…)delete操作数的值可以是空指针值指向由以前的新表达式创建的非数组对象的指针,或者指向子对象(1.8)的指针,该子对象表示这样的目标(第10条)。如果不是,则行为未定义。
相关文章:
- 析构函数调用
- 在具有向量的类构造函数中进行析构函数调用
- 从 c++ 中派生类的析构函数调用虚函数
- C++析构函数调用两次,堆栈分配的复合对象
- C++ 在析构函数调用之前删除的动态成员数组
- 析构函数调用c++中的一个向量
- Singleton模式中的手动析构函数调用:调用多次
- 从内部类的析构函数调用虚拟函数
- 与 boost odeint 集成期间的析构函数调用
- 堆栈展开如何与析构函数调用有关?
- C++:优化析构函数调用
- 以逗号分隔的表达式中的析构函数调用
- GCC 9.1 返回 void& 作为显式析构函数调用的结果类型。这是一个错误吗?
- 从C++中的虚拟析构函数调用虚拟方法
- 从指针返回对象时出现意外的析构函数调用
- 使用 decltype 显式析构函数调用
- C++析构函数调用了错误的对象
- 了解虚拟函数和析构函数调用
- 多重继承析构函数调用他自己和父析构函数?c++
- 析构函数调用表单不适当的库