从<T>派生类访问 Base 标识符是否必须>?
Is this-> mandatory to access Base<T> identifiers from derived classes?
此代码使用 MSVC 2015 编译,但不使用 Clang 5.0.0 编译(主干304874(:
template <typename T>
struct Base
{
T data;
};
template <typename T>
struct Derived : Base<T>
{
auto getData() const
{
return data;
}
};
在Derived::getdata()
中用this->data
代替data
让Clang感到高兴。
根据C++标准,哪个编译器是正确的?
是否必须在模板代码中使用this->
来访问基类的标识符?
Clang 是正确的。
$17.6.2/3 从属名称 [临时配置]
在类或类模板的定义中,在类模板或成员的定义点或类模板或成员的实例化期间,在非限定名称查找期间,都不会检查依赖基类的作用域。
对于return data;
,data
是不合格的,那么将采用不合格的名称查找。这意味着不应找到基类Base<T>
(这是一个依赖基类,因为它依赖于模板参数 T
(中的名称;即,非依赖名称不会在依赖基类中查找。
this->data
或Base<T>::data
使其合格。这意味着将在实例化时查找名称,届时将知道必须探索的确切基本专用化。
是的。基本上data
取决于T
.
有一种机制称为两阶段查找。非(模板(依赖名称在定义时立即解析。您的data
还不存在,因为Base<T>
还不存在,因为它尚未实例化。因此,它抱怨找不到data
。
您需要提示编译器data
依赖于模板,并且名称查找应在第二阶段执行,在模板参数被替换之后,即模板类被实例化。这可以通过使用this
或提供模板相关范围来完成。
因此,this->f()
或Base<T>::f()
都可以。
相关文章:
- 在提升multi_index容器中,是否定义了"default index"?
- 在C++STL中是否有Polyval(Matlab函数)等价物?
- 检查输入是否不是整数或数字
- 是否可以初始化不可复制类型的成员变量(或基类)
- 在C++中,是否可以基于给定的标识符创建基类的新实例,反之亦然
- 是否可以通过C++扩展强制多个python进程共享同一内存
- 此代码是否违反一个定义规则
- 是否需要删除包含对象的"pair"?
- 是否可以从int转换为enum类类型
- 无论条件是否为true,if总是在c++中执行
- 如何找到大小'x'数组是否完全填充,在C++?
- 检查值是否在集合p1和p2中,但不在p3中
- 是否可以在编译时初始化数组,以便在运行时不会花费时间?
- 检查 std::shared_ptr<> 的当前底层类型是否为 T
- 在c++中检查长方体是否尽可能快地重叠(无迭代)
- GL_SHADERSTORAGE_BUFFER位置是否与其他着色器位置冲突
- 子目录是否继承属性,例如add_definitions,include_directories和父Cmakelist.t
- 标准是否使用多余的大括号(例如 T{{{10}}})定义列表初始化?
- 是否需要使用 - &gt;运算符在C 中调用成员函数时
- 在修改列表后,std :: list&lt; t&gt; :: end()的值是否会更改