请注意,这只是一个关于模板语法的问题--不是一般的面向c++对象的多态设计。这个例子就是为了这个目的而制作的。
假设我有一个基类:
class A: public B
{
...
};我用它..。
A a;
a.DoSomething();如果我想做这样的事情,就能在编译时派生出A,不仅是从B,而且是从其他类。这样我就可以像这样使用它:
A<B> a; // like class A : public B
a.doSomething();
A<C> ac; // like class A : public C
ac.DoSomething();我能做这样的事吗?
template <typename BASECLASS>
class A : public BASECLASS
{
...
};让我们假设我的构造函数有一个参数,并且我知道我为hte基类使用的任何模板都有相同的签名。如果是,这是*.h文件,您如何处理*.cpp文件?初始化构造函数合法吗?
A::A(int param) : BASECLASS(param)
{
}请注意,这只是一个关于模板语法的问题--不是一般的面向c++对象、多态性设计。。
发布于 2013-12-20 19:23:05
在您的示例中,语法是正确的。下面是一个最小的可编译示例。
template <class Base>
class A : public Base {
};
class B {
public:
void doSomething() {}
};
class C {
public:
void doSomething() {}
};
int main() {
A<B> a; // like class A : public B
a.doSomething();
A<C> ac; // like class A : public C
ac.doSomething();
}发布于 2013-12-20 19:34:36
实际上,使用C++11,这变得更加容易了:
template <typename T>
class A: public T {
public:
template <typename... Args>
explicit A(Args&&... args): T(std::forward<Args>(args)...) {}
};这种使用可变模板参数(typename...)结合引用折叠(模板中的&&可以推断出最佳引用匹配)和std::forward允许完美转发;就好像A的构造函数的“层”是透明的。
https://stackoverflow.com/questions/20710534
复制相似问题