多個同名繼承函數:為什麼不重載?
在 C 中,當多個類別繼承同名但簽名不同的函數時,編譯器將這些函數視為不同的成員而不是重載函數。這會導致從衍生類別呼叫函數時出現歧義。
請考慮以下範例:
struct Base1 { void foo(int); }; struct Base2 { void foo(float); }; struct Derived : public Base1, public Base2 { };
這裡,Base1 和 Base2 都定義了一個名為 foo 且具有不同參數的函數。當從派生類別 Derived 呼叫 d.foo(5) 時,編譯器會引發「模糊呼叫」錯誤。
與要求函數簽名相同的覆蓋不同,重載允許具有相同名稱的函數,但不同的參數。但是,此規則不適用於多個繼承函數。
根據 C 成員找出規則,當衍生類別中存在多個相同成員名稱的聲明時,來自不同基底類別的聲明將被視為不明確。當聲明並非全部來自相同類型的子對象,或存在來自不同子對象的非靜態成員時,就會發生這種情況。
要解決這種歧義,您可以使用using 宣告來明確指定應呼叫哪個基底類別的函數:
struct Derived : public Base1, public Base2 { using Base1::foo; using Base2::foo; }; int main() { Derived d; d.foo(5); // Calls Base1::foo(int) d.foo(5.0f); // Calls Base2::foo(float) }
在第二個程式碼片段中,您提供:
struct Base { void foo(int); }; struct Derived : public Base { void foo(float); };
Derived 中的函數foo(float) 覆寫了基底類別中的foo(int) 函數。因此,當調用 d.foo(5) 時,foo(float) 函數被正確調用,沒有任何歧義。
以上是為什麼 C 中同名的多個繼承函數不重載?的詳細內容。更多資訊請關注PHP中文網其他相關文章!