如何从类模板派生
How to derive from class template
本文关键字:派生 更新时间:2023-10-16
我正在阅读有关模板的书,并在以下示例中找到了突出显示模板关键字的使用的示例。我尝试以下示例,但它给出了错误
令牌之前的预期模板名称<D类:公共外壳::模板>
#include <iostream>
using namespace std;
template <typename T>
class shell {
public:
template<int N>
class in {
public :
template <int M>
class Deep {
public:
virtual void f() { cout << endl << "NO" << endl; }
};
};
};
template <typename T, int N>
class weird
{
public:
void case1(typename shell<T>::template In<N>::template Deep<N>* n)
{
class D : public shell<void>::template In<N>::template Deep<N>
{
public :
virtual void f() { cout << endl << "N" << endl;}
};
n = new D();
n-> f();
}
};
int main() {
weird<void,1> obj;
obj.case1(NULL);
return 0;
}
提前致谢
您在其中一个类中使用了错误的大小写:
void case1(typename shell<T>::template In<N>::template Deep<N>* n)
// ^^^^^
应该是:
void case1(typename shell<T>::template in<N>::template Deep<N>* n)
其他一切都很好。
相关文章:
- 为什么使用 "this" 指针调用派生成员函数?
- 具有奇怪重复模板模式的派生类中的成员变量已损坏
- 在派生函数中指定void*参数
- 如何通过派生类函数更改基类中的向量
- 如何委托派生类使用其父构造函数?
- 如何使用单独文件中的派生类访问友元函数对象
- 派生类销毁的最佳实践是什么
- 如何使用基类指针引用派生类成员
- 派生类是否可以在抽象工厂设计模式中具有数据成员
- 使用基类指针创建对象时,缺少派生类析构函数
- 如何引用基类的派生类?
- 存储模板类型以强制转换回派生<T>
- 需要从 istream 和 ostream 派生 iostream
- 在 C++ 中用派生类型重写成员函数
- 具有多个类、派生类的C++正向声明
- 有没有一种"cleaner"的方法可以在指向基的指针向量中找到派生类的第一个实例?
- 用常见虚拟函数实现的任意组合来实现派生类的正确方法是什么
- 如果基类包含双指针成员,则派生类的构造函数
- 为什么此派生对象无法访问基类的后递减方法?
- 有没有比在库中添加一个并非由所有派生类实现的新虚拟函数更好的设计实践