A 的析构函数将在其生命周期结束时运行。如果你想释放它的内存并运行析构函数,如果它是在堆上分配的,你必须删除它。如果它是在堆栈上分配的,这会自动发生(即,当它超出范围时;请参阅 RAII)。如果它是类的成员(不是指针,而是完整成员),那么当包含对象被销毁时就会发生这种情况。
class A
{
char *someHeapMemory;
public:
A() : someHeapMemory(new char[1000]) {}
~A() { delete[] someHeapMemory; }
};
class B
{
A* APtr;
public:
B() : APtr(new A()) {}
~B() { delete APtr; }
};
class C
{
A Amember;
public:
C() : Amember() {}
~C() {} // A is freed / destructed automatically.
};
int main()
{
B* BPtr = new B();
delete BPtr; // Calls ~B() which calls ~A()
C *CPtr = new C();
delete CPtr;
B b;
C c;
} // b and c are freed/destructed automatically
在上面的例子中,每个 delete 和 delete[] 都是需要的。在我没有使用它的地方不需要删除(或者确实可以使用)。
auto_ptr
,unique_ptr
等等shared_ptr
......非常适合使这一生命周期管理变得更加容易:
class A
{
shared_array<char> someHeapMemory;
public:
A() : someHeapMemory(new char[1000]) {}
~A() { } // someHeapMemory is delete[]d automatically
};
class B
{
shared_ptr<A> APtr;
public:
B() : APtr(new A()) {}
~B() { } // APtr is deleted automatically
};
int main()
{
shared_ptr<B> BPtr = new B();
} // BPtr is deleted automatically