指针c ++的模板数组?
Posted
技术标签:
【中文标题】指针c ++的模板数组?【英文标题】:Template array of pointers c++? 【发布时间】:2016-07-22 13:26:27 【问题描述】:大家好,在我的 c++ 程序中,我有四个类(A、B、C、D)
A 是基类 B 继承自 A C 继承自 A D 继承自 B它们都是模板类template<class Type>
,每个都有一个打印方法,打印它的私有成员和它继承的类的私有成员。
所以 B 将打印 B 私有成员和 A 私有成员,C 将打印 C 私有成员和 A 私有成员,D 将打印其私有成员和 B,A 私有成员。
在主函数中,我想为类 A 创建一个指针数组,其中每个类的对象有 3 个位置,然后我想循环每个对象的打印方法。
问题是当我将类更改为模板类时,我收到一条错误消息“我的类没有构造函数”;但是他们确实有。
这是我的代码,请帮助(注意我已为您注释了发生错误的位置):
#include <iostream>
#include <string>
using namespace std;
template <class Type>
class A
public:
virtual void print()
cout<<"the base class (A) private (x) is : "<<x<<endl;
A(Type X = 0)
x = X;
void setX(Type X)
x = X;
Type getX() const
return x;
private:
Type x;
;
template <class Type>
class B:public A
public:
B(Type X = 0,Type Y = 0)
setX(X);
y = Y;
void setY(Type Y)
y = Y;
Type getY() const
return y;
void print()
A::print();
cout<<"private (y) in class (B) is : "<<getY()<<endl;
private:
Type y;
;
template <class Type>
class C:public A
public:
C(Type X = 0,Type Z = 0)
setX(X);
z = Z;
void setZ(Type Z)
z = Z;
Type getZ() const
return z;
void print()
A::print();
cout<<"private (z) in class (C) is : "<<getZ()<<endl<<endl;
private:
Type z;
;
template <class Type>
class D:public B
public:
D(Type X = 0,Type Y = 0,Type W = 0)
setX(X);
setY(Y);
w = W;
void setW(Type W)
w = W;
Type getW() const
return w;
void print()
B::print();
cout<<"private (w) in class (D) is : "<<getW()<<endl;
private:
Type w;
;
void main()
A<int>* arrayOfPointers[3];
arrayOfPointers[0] = new B(1,100);//error here
arrayOfPointers[1] = new C(2,200);//error here
arrayOfPointers[2] = new D(3,300,3000);//error here
for(int i = 0 ; i<3;i++)
cout<<typeid(*arrayOfPointers[i]).name()<<" Print method : \n"<<endl;
arrayOfPointers[i]->print();
cout<<"**********************\n"<<endl;
【问题讨论】:
在 SO 上发帖时,尝试提出仍然显示错误的最小示例,并提供确切的错误消息。您可能只需要 A & B 即可在此处产生错误,因此您可以将代码减半。 在class B:public A
A
你继承自什么?由于A
是一个模板,它的名字是不够的。
我认为All of them are template classes
是您误解的症状。它们是类模板。这意味着如果您有template <typename Type> class A
,那么A
本身就不是一个类。只有在您指定了所有模板参数后,它才会成为一个实际的类。所以 A<int>
例如将是一个类。
好的,谢谢大家,下次我会确保让我的问题变小
【参考方案1】:
你忘记了两件事:
1) 你的继承需要为它们继承的类指定模板参数。例如:
template <class Type>
class B : public A<Type>
...
2) 当你实例化你的类时,你也需要提供模板参数:
arrayOfPointers[0] = new B<int>(1, 100);
arrayOfPointers[1] = new C<int>(2, 200);
arrayOfPointers[2] = new D<int>(3, 300, 3000);
但是,您也可以提供模板函数来从提供的参数实例化这些类,例如 std 库中的 make_(...) 方法:
template <class Type>
B<Type>* create_B(const Type& t1, const Type& t2)
return new B<Type>(t1, t2);
并像这样使用它:
arrayOfPointers[0] = create_B(1, 100);
但是,请注意,这些方法正在创建指向已分配堆内存的原始指针,因此您有责任删除它(您可以使用 shared_ptrs 或其他方法来克服这一点,或者只是返回一个对象等,但这实际上并不是您的一部分问题/我的回答)。
【讨论】:
【参考方案2】:您从A
继承,但您应该从特定实例化A<T>
继承。也许class B:public A<Type>
?
【讨论】:
as for 1)A(Type X = 0)
是默认构造函数的有效替代品。至于3)他已经有一个指针数组
对,删除了第一个(我已经注意到并删除了第三个)以上是关于指针c ++的模板数组?的主要内容,如果未能解决你的问题,请参考以下文章