上篇文章寫了:Java中構造方法的執行順序,這次是C++中建構函式的執行順序。
經測試按照如下順序:
一、先執行靜態成員的建構函式,如果靜態成員只是在類定義中聲明了,而沒有實現,是不用構造的。必須初始化後才執行其建構函式。
二、任何抽象基類的建構函式按照它們被繼承的順序構造(不是初始化列表中的順序)
三、任何虛擬基類的建構函式按照它們被繼承的順序構造(不是初始化列表中的順序)
四、任何非虛擬基類的建構函式按照它們被繼承的順序構造(不是初始化列表中的順序)
五、任何成員對象的建構函式按照它們聲明的順序構造
六、類自己的建構函式
測試程式如下:
#include <iostream>#include <string>using namespace std;//抽象類別Aclass A{public:A(){cout<<"抽象類別A的建構函式"<<endl;}//純虛函數funvirtual void fun1() = 0;};//抽象類別Bclass B{public:B(){cout<<"抽象類別B的建構函式"<<endl;}//純虛函數funvirtual void fun2() = 0;};//普通類Cclass C{public:C(){cout<<"類C的建構函式"<<endl;}};//普通類Dclass D{public:D(){cout<<"類D的建構函式"<<endl;}};//普通類Cclass E{public:E(){cout<<"類E的建構函式"<<endl;}};//普通類Dclass F{public:F(){cout<<"類F的建構函式"<<endl;}};//普通類Dclass G{public:G(){cout<<"類G的建構函式"<<endl;}};//普通類Dclass H{public:H(){cout<<"類H的建構函式"<<endl;}};//普通類Dclass M{public:M(){cout<<"類M的建構函式"<<endl;}};class Test: public A,public B,virtual public C,virtual public D,public E,public F{public:Test():B(),A(),D(),C(),F(),E(){cout<<"類Test的建構函式"<<endl;}void fun1(){}void fun2(){}private:G g;static H h;static M m;};H Test::h;int main(int argc, char* argv[]){Test test;return EXIT_SUCCESS;}
結果:
類H的建構函式
類C的建構函式
類D的建構函式
抽象類別A的建構函式
抽象類別B的建構函式
類E的建構函式
類F的建構函式
類G的建構函式
類Test的建構函式