如何在C++中删除新操作符占用的内存

how to delete memory occupied by new operator in C++

本文关键字:操作符 内存 删除 C++      更新时间:2023-10-16

可能重复:
为什么使用"new"会导致内存泄漏?

我是C++内存评测的新手。Valgrind报告线路发生泄漏

m_propertyManager(new coral::PropertyManager);

所以我把它修改成

coral::PropertyManager Mgr;
m_propertyManager(&Mgr);

我想&Mgr是自动删除的,但再次valgrind报告了这方面的泄漏。

new coral::PropertyManager在堆上分配了一个新的PropertyManager,但由于它是一个临时变量,您永远不会释放它。这是标准的Java习惯用法,因为Java是一种垃圾收集语言,GC将负责为您释放这个悬空引用。

如果出于某种原因想要在这里使用new,正确的方法如下:

auto *pm = new coral::PropertyManager; // auto is C++11 syntax
m_propertyManager(pm);
delete pm; // when you're done using it

您的第二个选项是正确的,因为它将Mgr分配为堆栈上的一个自动变量,该变量将在函数退出时释放。m_propertyManager(&Mgr);将Mgr的地址传递给函数,这将允许它修改Mgr对象(尽管将Mgr作为引用传递可能会更好(。

请注意,如果m_propertyManager是一个在当前作用域退出后仍然存在的对象,并且它将对Mgr的引用存储在某个位置,那么当您退出当前作用域并销毁Mgr对象时,您会发现m_propertyManager包含对无效内存的引用。

如果使用new分配内存,则必须使用delete在某个位置释放内存。如果m_propertyManager不应该管理PropertyManager的生存期,它只会丢弃指针,留下已分配的内存,并且没有访问权限。

另一方面,您的第二个解决方案将崩溃。外观:

{
    coral::PropertyManager Mgr;
    m_propertyManager->SetManager(&Mgr); // You pass pointer to Mgr here
}
// Here Mgr no longer exists, so m_propertyManager
// now contains the pointer to non-existing object

您应该:

  • 动态创建PropertyManager(使用new(,在某个位置保持指向它的指针,并在某个点使用delete显式释放它
  • PropertyManager中实现move-contor并传递值(这样m_propertyManager将隐式自动分配自己的PropertyManager实例(
  • 使用静态分配(如第二个示例中所示(,但将实例保留在该位置,在该位置它将保持活动至少m_propertyManager一样长
  • 在m_propertyManager中使用某种自动指针(如std::shared_ptr或std::unique_ptr(