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

Is it possible to store function parameters as some kind of list

我有基地class

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

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));
}
...

但由于这是一个模板 class,我需要该列表适应任何类型或数量的参数 T 需要。有没有办法做到这一点,或者你知道更好的方法来做我想做的事吗?

模板 class 可以有一个进一步的模板化构造函数。在你的情况下,你需要一个接受参数包并进行(非完美)转发的:

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...);
    }  
};

应该就可以了。只需在 Derived class 的构造函数中将参数传递给 Base<Bar> 的构造函数即可。

我强调非完美转发的原因是如果我们将参数std::forward插入到第一个插入的项目中,它可能会移动它们,从而使它们对第二个项目无效。 YMMV,你要慎重考虑。