簡略引見C++編程中派生類的析構函數。本站提示廣大學習愛好者:(簡略引見C++編程中派生類的析構函數)文章只能為提供參考,不一定能成為您想要的結果。以下是簡略引見C++編程中派生類的析構函數正文
和結構函數相似,析構函數也是不克不及被繼續的。
創立派生類對象時,結構函數的挪用次序和繼續次序雷同,先履行基類結構函數,然後再履行派生類的結構函數。然則關於析構函數,挪用次序正好相反,即先履行派生類的析構函數,然後再履行基類的析構函數。
請看上面的例子:
#include <iostream>
using namespace std;
class A{
public:
A(){cout<<"A constructor"<<endl;}
~A(){cout<<"A destructor"<<endl;}
};
class B: public A{
public:
B(){cout<<"B constructor"<<endl;}
~B(){cout<<"B destructor"<<endl;}
};
class C: public B{
public:
C(){cout<<"C constructor"<<endl;}
~C(){cout<<"C destructor"<<endl;}
};
int main(){
C test;
return 0;
}
運轉成果:
A constructor B constructor C constructor C destructor B destructor A destructor
從運轉成果可以很顯著地看出來,結構函數和析構函數的履行次序是相反的。
須要留意的是,一個類只能有一個析構函數,挪用時不會湧現二義性,所以析構函數不須要顯式地挪用。