簡略引見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
從運轉成果可以很顯著地看出來,結構函數和析構函數的履行次序是相反的。
須要留意的是,一個類只能有一個析構函數,挪用時不會湧現二義性,所以析構函數不須要顯式地挪用。