GCC 嚴格執行範本參數相依性
所提供的程式碼會引發使用GCC 時出現的問題,但使用Visual Studio 時不會出現該問題。以下程式碼:
<code class="cpp">template <typename T> class A { public: T foo; }; template <typename T> class B: public A<T> { public: void bar() { cout << foo << endl; } };</code>
使用 GCC 編譯失敗,但使用 Visual Studio 編譯成功。錯誤提示開發者加入這個->到表達式中以存取方法 bar 中的成員 foo。
此行為源自於 GCC 嚴格遵守 C 規範。早期版本的 GCC 透過解析模板基底類別來推斷成員存取。然而,ISO C 認為這種推論有潛在問題,因此已棄用它。
這種情況下的解決方案是使用 this-> 明確引用成員 foo。或明確指定基類,如下例所示:
<code class="cpp">template <typename T> class A { public: T foo; }; template <typename T> class B: public A<T> { public: void bar() { cout << A<T>::foo << endl; } };</code>
藉由這樣做,GCC 可以確定基類的類型並相應地解析成員存取。
以上是為什麼 GCC 要求模板基類成員具有明確成員存取權限?的詳細內容。更多資訊請關注PHP中文網其他相關文章!