关于析构函数的一些

本文深入解析析构函数的特性与应用场景,包括其无参、不可重载的特点,以及在内存管理中的作用。通过实例演示new/delete与malloc/free在调用析构函数上的区别,揭示析构函数在对象生命周期结束时的自动调用机制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.析构函数,比构造函数多一个~和构造函数一样,没有返回值
2.析构函数总是无参的,不能重载
3.语法上允许多次调用析构函数,且什么时候释放什么时候调用析构函数
4.在用类类型开辟内存空间时,Malloc free 不会调用析构函数,而new delete 会调用
例子如下

#include<iostream>
using namespace std;
class People     //简单定义了一个类,为了简洁,我把其成员函数的定义放在文章最后,其成员函数的功能只是简单的输出对象的地址
{
    int age;
public:
    void show_age();
    People(int n);
    People();
    ~People();
};
int main()
{
   People* p = new People;     
    People a(5);
    People b(6);
    a.show_age(); //成员函数
    delete p;     //会发现在delete之后就调用析构函数输出了
    b.show_age(); //成员函数
    return 0;

而如果使用c中的malloc

    People* p = (People*)malloc(sizeof People);
    free(p);// 如果使用malloc开辟空间,释放时不会调用析构函数

还有一些特性,关于释放顺序

       //  先创建的后释放
    People p[5];
    p[0].~People();//可以人为调析构函数,但是在销毁时系统还是会调用析构函数
    p[0].~People();
    delete[] p;
    return 0;
}

成员函数在这里,有兴趣的可以复制代码,看看析构函数释放时释放的顺序


    People::People(int n)
{
    this->age = n;
}
People::People()
{
    this->age = 0;
    cout << this << endl;
}
People::~People()
{
    cout << this << endl;
}
void People::show_age()
{
    cout << this <<"   "<< age << endl;
}

萌新学习中,如有不对之处,请多多指教!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值