C++構造函數的執行順序遵循以下規則:
基類構造函數:首先調用基類的構造函數。如果基類沒有默認構造函數(無參數的構造函數),則需要顯式地調用一個帶參數的基類構造函數。
成員變量初始化列表:在基類構造函數調用之后,構造函數將按照成員變量在類定義中的聲明順序初始化類的成員變量。可以使用成員初始化列表來初始化成員變量,這樣可以提供更好的性能,并允許對常量和引用類型的成員變量進行初始化。
構造函數體:最后執行構造函數的函數體。在這個階段,可以執行一些額外的操作,比如分配內存、初始化指針等。
析構函數:當構造函數執行完畢后,對象的析構函數將按照相反的順序被調用。首先調用派生類的析構函數,然后是基類的析構函數。這是為了確保在對象銷毀之前,所有資源都被正確地釋放。
以下是一個簡單的例子,展示了構造函數的執行順序:
#include <iostream>
class Base {
public:
Base(int x) : a(x) {
std::cout << "Base constructor called with value: "<< a << std::endl;
}
~Base() {
std::cout << "Base destructor called" << std::endl;
}
private:
int a;
};
class Derived : public Base {
public:
Derived(int x, int y) : Base(x), b(y) {
std::cout << "Derived constructor called with values: "<< a << ", "<< b << std::endl;
}
~Derived() {
std::cout << "Derived destructor called" << std::endl;
}
private:
int b;
};
int main() {
Derived d(1, 2);
return 0;
}
輸出結果:
Base constructor called with value: 1
Derived constructor called with values: 1, 2
Derived destructor called
Base destructor called
在這個例子中,首先調用基類Base
的構造函數,然后是派生類Derived
的構造函數。當對象d
被銷毀時,析構函數的調用順序是相反的,首先是派生類的析構函數,然后是基類的析構函數。