在 C 中,定义类模板时,在非限定名称查找期间不会检查基类范围,如果基类依赖于模板参数。 C 标准的 14.6.2/3 中概述了此行为。
考虑以下代码:
template<typename T> class A { public: typedef std::vector<T> Vec_t; }; template<typename T> class B : public A<T> { private: Vec_t v; // fails - Vec_t is not recognized };
在此示例中,B 类继承自 A 类模板,其中包含类型别名 Vec_t。但是,在 B 类中,尝试使用 Vec_t 而不完全限定它(即 A
要解决此问题,类型别名的名称必须在 B 类中完全限定:
template<typename T> class B : public A<T> { private: typename A<T>::Vec_t v; // correct - fully qualified name };
这是因为,在非限定名称查找期间在类模板或其成员的定义中,如果基类依赖于模板参数,则不会检查基类范围。因此,有必要显式限定类型别名的名称以避免编译器错误。
以上是为什么非限定名称查找不能与 C 中的模板参数相关基类一起使用?的详细内容。更多信息请关注PHP中文网其他相关文章!