首頁 > 後端開發 > C++ > 為什麼 C 中同名的多個繼承函數不重載?

為什麼 C 中同名的多個繼承函數不重載?

Patricia Arquette
發布: 2024-12-21 16:17:09
原創
604 人瀏覽過

Why Don't Multiple Inherited Functions with the Same Name Overload in C  ?

多個同名繼承函數:為什麼不重載?

在 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中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板