C ++:从模板参数继承

用户名

在下一个代码示例中:

#include <iostream>
using namespace std;
int f() {
    return 0;
}
struct A {
    int f()    {
        return 1; }
};
template<class T>
struct C : public T {
    C() {
        cout << f() << endl;
    } };
int main() {
    C<A> c; // prints 0
    return 0;
}

如果我将继承更改为非模板,如下所示: struct C : public A

然后它会显示“ 1”而不是0。

这是为什么?

TC

f()f是一个非依赖的名字,所以名字查找发生在模板定义时间(之前T是已知的),并结合它::f如果希望它调用成员函数f,则使用this它作为从属名称:

template<class T>
struct C : public T {
    C() {
        cout << this->f() << endl;
    } 
};

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章

来自分类Dev

C ++ 11中的可变参数模板和多重继承

来自分类Dev

通过可变参数模板的C ++ 11构造函数继承

来自分类Dev

通过可变参数模板的C ++ 11构造函数继承

来自分类Dev

<sizeof(T)>作为C ++中的继承类模板参数

来自分类Dev

C ++继承模板类

来自分类Dev

C ++模板继承

来自分类Dev

C ++模板类继承

来自分类Dev

c ++模板继承方案

来自分类Dev

C ++继承模板类

来自分类Dev

C ++模板和继承

来自分类Dev

C ++模板抽象继承

来自分类Dev

C ++:使用参数包具有可变类型参数的模板类继承

来自分类Dev

模板参数的C ++模板参数

来自分类Dev

检查C ++类是否使用匿名参数从模板类公开继承

来自分类Dev

模棱两可的错误:C ++ 11使用可变参数模板多重继承

来自分类Dev

从Visual C ++中的unordered_map继承时,模板参数的sizeof()不正确

来自分类Dev

模棱两可的错误:C ++ 11使用可变参数模板多重继承

来自分类Dev

从Visual C ++中的unordered_map继承时,模板参数的sizeof()不正确

来自分类Dev

C ++:从模板类继承并带有可能变化的构造函数参数

来自分类Dev

从c ++模板类继承的问题

来自分类Dev

继承和模板函数C ++

来自分类Dev

c ++从模板结构继承

来自分类Dev

模板中C ++继承中的模板类

来自分类Dev

模板类参数继承

来自分类Dev

C ++隐藏模板参数

来自分类Dev

模板参数推导C ++

来自分类Dev

C ++模板返回参数

来自分类Dev

分配C ++模板参数

来自分类Dev

C ++模板打包参数