存取模板化父類中的繼承的受保護變數
嘗試從C 中的模板化父類存取受保護的繼承變數時會出現此問題。考慮以下 C 程式碼:
template<class T> class Foo { protected: int a; }; template<class T> class Bar : public Foo<T> { protected: int b; }; template<class T> int Bar<T>::Perna(int u) { int c = Foo<T>::a * 4; // This works return (a + b) * u; // This doesn't }
在這種情況下,GCC 版本 3.4.6 及更高版本在嘗試存取繼承的 Foo 類別的受保護變數 a 時會引發錯誤。較舊的編譯器,包括 GCC 2.96 和 MSVC 6-9,允許此存取而不會出現問題。
錯誤解釋
發生錯誤的原因是,根據 C 標準,不合格在模板定義期間必須查找模板中的名稱。但是,在範本定義時可能不知道依賴基底類別(例如本例中的 Foo)的定義。這種不確定性阻礙了不合格名稱的解析。
標準合規性
GCC 3.4.6 及更高版本所表現出的行為符合 C 標準。透過遵守標準,這些編譯器可確保程式碼的正確性和行為在不同平台和編譯器之間保持一致。
解決方案
要解決此問題並訪問受保護的繼承對於變量,可以使用變量的限定名稱(例如Foo
template<class T> int Bar<T>::Perna(int u) { int c = this->a * 4; // Access using the qualified name c = a * 4; // Access using the "using" declaration }
在此修改後的程式碼中,限定名稱或「using」聲音明顯式指定 a 變數的來源,允許編譯器正確解析它。
以上是如何在 C 中存取模板化父類別中受保護的繼承變數?的詳細內容。更多資訊請關注PHP中文網其他相關文章!