重寫C 中的重載函數
考慮這樣一種情況:派生類別重寫其基底類別中重載的函數。重寫後,您可能會遇到錯誤,指示衍生類別中缺少重載函數。此行為不是設計缺陷,而是 C 繼承機制的結果。
預設情況下,當類別重寫成員函數時,僅在衍生類別的範圍內考慮重寫的版本。因此,基類中函數的任何重載版本都不再可存取。
要解決此問題並保留重載功能,可以在衍生類別中使用 using 指令:
class bar : public foo {
using foo::a; // Bring overloads from 'foo' into 'bar'
};
using 指令明確指定 foo 類別中的 a 重載應該在 bar 類別中可用。這允許衍生類別存取和使用該函數的所有重載版本。
需要注意的是,如果基底類別和衍生類別中都存在相同的重載,則使用 using 指令可能會引入歧義。此外,如果現有程式碼依賴基類重載的特定行為,則引入新的重載可能會改變其預期功能。因此,建議使用此技術時務必小心。
免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。
Copyright© 2022 湘ICP备2022001581号-3