详见这位大佬:
https://blog.csdn.net/c_base_jin/article/details/74787976
同时:与构造函数相反,当对象结束其生命周期,如对象所在的函数已调用完毕时,系统会自动执行析构函数。以C++语言为例:析构函数名也应与类名相同,只是在函数名前面加一个位取反符~,例如~stud( ),以区别于构造函数。它不能带任何参数,也没有返回值(包括void类型)。只能有一个析构函数,不能重载。如果用户没有编写析构函数,编译系统会自动生成一个缺省的析构函数(即使自定义了析构函数,编译器也总是会为我们合成一个析构函数,并且如果自定义了析构函数,编译器在执行时会先调用自定义的析构函数再调用合成的析构函数),它也不进行任何操作。所以许多简单的类中没有用显式的析构函数。(百度百科)
举例:
#include<string.h>
#include<iostream>
using namespace std;class stud{
private:
int num;
char name[10];
char sex;
public:
stud(int n,const char nam[],char s){
num=n;
strcpy(name,nam);
sex=s;
}
~stud(){
cout<<"已经被调用!"<<endl; //析构函数
}
void dispaly(){
cout<<"num:"<<num<<endl;
cout<<"name:"<<name<<endl;
cout<<"sex:"<<sex<<endl;
}
};int main(){
stud stud1(10010,"wangwei",'m');
stud stud2(10011,"limei",'f');
stud1.dispaly();
stud2.dispaly();
return 0; //结果中应该调用了析构函数
}
析构函数的作用:当对象被调用完后,处理善后工作,来撤销对象。在函数中建立对象之后,这个对象作为局部对象开始生存,直到函数运行到遇见右括号“}”才结束生存,此时调用析构函数。
对象的释放发生在以下几种情况: (摘自腾讯云 https://cloud.tencent.com/developer/article/1087503)
使用运算符new分配的对象被delete删除。
一个具有块作用域的本地(自动)对象超出其作用域。
临时对象的生存期结束。
程序结束运行。
使用完全限定名显示调用对象的析构函数。