c++析构函数是怎么释放内存的?

2024-12-20 08:28:48
推荐回答(4个)
回答1:

你在方法2中可能实例化类1时没有初始化指针,或者指针为空,程序结束时,调用析构函数delete一个野指针或空指针的时候就可能会出错了,而你把方法1的指针换成对象,在程序结束的时候,即使你没有清理,编译器都会帮你释放空间的,因此不会出错。

回答2:

自动生成的只会原样复制。如果你的类里有一个指针,你给它分配了内存,然后在析构函数中释放内存。如果使用自动生成的复制函数会造成重复释放内存。

如果我用了new来分配内存 我又使用了 析构函数来释放内存 会怎样呢?
class C
{
public:
C() : p( new char[ 100 ])
{}
~C()
{
delete[] p;
}
private:
char *p;
};
C a;
C b(a); //这里使用系统生成的拷贝构造函数。a.p 与b.p是相同的。a和b的析构函数都会删除p,就会重复删除而出错。

回答3:

需要贴代码

回答4:

关于析构函数的说明:
1。当程序的执行离开实例化自动对象所在的作用域时,自动对象就会撤销,这时析构函数隐式调用.并不是说在main函数结束时才执行。
2。析构函数本身并不释放对象占用的内存空间,它只是在系统收回对象的内存空间之前执行扫尾工作.析构函数体内并不一定要有delete语句。可以有也可以没
3。和构造函数一样,每个类都有一个析构函数,即使没有显式提供一个析构函数,编译器也会生成一个空的析构函数 .
补充说明:
离开实例化自动对象所在的作用域这句的意思就是说比如你有一个自定义类和一个自定义函数,你在这个函数里声明一个这个类的对象,这个对象就是实例化自动对象,它的作用域仅限于该函数体内,然后你在main函数里调用这个函数,调用结束后,那个类的对象就离开了它的作用域,这时,那个类的析构函数就会被编译器隐式调用。
当主函数结束,回收内存的工作就开始了,但这个工作是由编译器的内存回收机制在后台执行。如果在类的实现中,有动态分配内存和动态分配数组的语句,那么最好在析构函数里提供delete语句!
更正二楼的一个观点,析构函数绝不是在main函数结束时自动执行的!!!!!!