我有一个基类
template<class T>
class Base
{
public:
Base(T foo = T())
{
for(int i = 0; i < 10; i++)
foos.push_back(foo);
}
private:
std::vector<T> foos;
}
我有一个派生类
class Derived : public Base<Bar>
{
public:
Derived() : Base(Bar("somerandomparameter")) {}
}
我想要这样做,就是使用提供的构造函数创建一个包含10个新Bars的向量(无论它是什么)。
我想过创建一个自定义复制构造函数但是这没有按预期工作,因为看起来push_back方法创建了更多的副本,至少我的Bar
构造函数被调用超过10次。
对我来说,最佳解决方案就是传递一个参数列表,因为这只会创建我想要的10个对象。
...
Base(ParameterList l)
{
for(int i = 0; i < 10; i++)
foos.push_back(T(l));
}
...
但由于这是一个模板类,我需要该列表适应T
所需的任何类型或数量的参数。有没有办法做到这一点,或者你知道一种更好的方式做我想做的事情吗?
答案 0 :(得分:4)
模板类可以有一个进一步的模板化构造函数。在您的情况下,您需要一个接受参数包并进行(非完美)转发:
template<class T>
class Base
{
std::vector<T> foos;
public:
template<typename... Args>
Base(Args&&... args)
{
foos.reserve(10);
for(int i = 0; i < 10; i++)
foos.emplace_back(args...);
}
};
那应该这样做。只需将参数传递给Base<Bar>
类构造函数中Derived
的构造函数。
我强调非完美转发的原因是,如果我们std::forward
插入第一个项目的参数,它可能会移动它们,从而使它们对第二个项目无效。 YMMV,你应该仔细考虑。