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中文网其他相关文章!