繼承建構子
您提供的程式碼片段:
class A { public: explicit A(int x) {} }; class B: public A { }; int main(void) { B *b = new B(5); delete b; }
使用GCC 編譯時會產生錯誤,因為它缺少B(int) 的匹配建構子。雖然您可能期望 B 繼承 A 的建構函數,但 C 中預設並非如此。
在 C 11 及更高版本中,引入了名為 構造函數繼承 using using 的新功能。透過新增使用 A::A;在類別 B 中,您可以明確繼承 A 的所有建構子。
class A { public: explicit A(int x) {} }; class B: public A { using A::A; };
但是,建構子繼承是一個全有或全無的概念。您不能選擇性地僅繼承某些建構函式。如果您嘗試這樣做,則需要手動定義所需的建構函式並明確地呼叫每個建構函式的基本建構函式。
在 C 03 及更早版本中,不支援建構子繼承。必須透過在每個衍生類別建構函式中單獨呼叫基底構造函數來手動繼承建構函式。
對於模板化基類,您可以使用模板語法來繼承所有建構子。例如:
template<class T> class my_vector : public vector<T> { public: using vector<T>::vector; ///Takes all vector's constructors /* */ };
以上是如何繼承 C 中的建構子?的詳細內容。更多資訊請關注PHP中文網其他相關文章!