是否可以将函数参数存储为某种列表

时间:2017-11-19 11:48:46

标签: c++ function parameters template-classes

我有一个基类

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所需的任何类型或数量的参数。有没有办法做到这一点,或者你知道一种更好的方式做我想做的事情吗?

1 个答案:

答案 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,你应该仔细考虑。