函式介紹
與
構造函式相反,當對象結束其
生命周期,如對象所在的函式已調用完畢時,系統會自動執行析構函式。以C++語言為例:析構函式名也應與類名相同,只是在函式名前面加一個位取反符~,例如~stud( ),以區別於
構造函式。它不能帶任何參數,也沒有返回值(包括void類型)。只能有一個析構函式,不能
重載。如果用戶沒有編寫析構函式,
編譯系統會自動生成一個預設的析構函式(即使自定義了析構函式,
編譯器也總是會為我們合成一個析構函式,並且如果自定義了析構函式,編譯器在執行時會先調用自定義的析構函式再調用合成的析構函式),它也不進行任何操作。所以許多簡單的類中沒有用顯式的析構函式。
函式定義
C++當中的析構函式格式如下:
class <類名>{ public: ~<類名>();};<類名>::~<類名>(){ //函式體}
如以下定義是合法的:
class T{ public: ~T();}; T::~T(){ //函式體}
當程式中沒有析構函式時,系統會自動生成以下析構函式:
<類名>::~<類名>(){},即不執行任何操作。
作用
下面通過一個例子來說明一下析構函式的作用:
#include<iostream>using namespace std;class T{ public: ~T(){cout<<"析構函式被調用。";} //為了簡潔,函式體可以直接寫在定義的後面,此時函式為內聯函式};int main(){ T *t=new T();//建立一個T類的指針對象t delete t; cin.get();};
最後輸出:
析構函式被調用。
cin.get() 表示從鍵盤讀入一個字元,為了讓我們能夠看得清楚結果。當然,析構函式也可以顯式的調用,如 (*t).~T(); 也是合法的。
程式實例
c++語言程式
#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<<"stud has been destructed!"<<endl;//通過輸出提示告訴我們析構函式確實被調用了 } void display()//成員函式,輸出對象的數據 { cout<<"num:"<<num<<endl; cout<<"name:"<<name<<endl; cout<<"sex:"<<sex<<endl; }};int main(){ stud stud1(10010, "Wang-li", 'f'), stud2(10011, "Zhang-fun", 'm');//建立兩個對象 stud1.display();//輸出學生1的數據 stud2.display();//輸出學生2的數據 return 0;}//主函式結束的同時,對象stud1,stud2均應被“清理”,而清理就是通過調用了析構函式實現的。/**********************輸出結果:num:10010name:Wang-lisex:fnum:10011name:Zhang-funsex:mstud has been destructed!stud has been destructed!***********************/
把類的聲明放在
main函式之前,它的
作用域是全局的。這樣做可以使main函式更簡練一些。在main函式中定義了兩個對象並且給出了初值,然後輸出兩個學生的數據。當
主函式結束時調用析構函式,輸出stud has been destructe!。值得注意的是,真正實用的析構函式一般是不含有輸出信息的。
在本程式中,成員函式是在類中定義的,如果成員函式的數目很多以及函式的長度很長,類的聲明就會占很大的篇幅,不利於閱讀程式。而且為了隱藏實現,一般是有必要將類的聲明和實現(具體方法代碼)分開編寫的,這也是一個良好的編程習慣。即可以在類的外面定義成員函式,而在類中只用函式的原型作聲明。
Python語言程式
#!/user/bin/python#-*-coding:UTF-8-*-from __future__ import print_function # 兼容python2.x和python3.x的print語句class Fruit(object): def __init__(self,color):# 初始化屬性__color self.__color = color print(self.__color) def __del__(self):# 析構函式 self.__color = "" print("free...") def grow(self): print("grow...")if __name__=="__main__": color = "red" fruit = Fruit(color) fruit.grow()