是否可以将函数参数存储为某种列表
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,你要慎重考虑。
我有基地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,你要慎重考虑。