我正在寻找香草C++98解决方案(没有提升或qt等)
有没有办法做这样的事情:
// valid in c++ 11
std::vector<Foo> vFoo {Foo1, Foo2, Foo3, Foo4} ;
或类似的东西
// Well it is C# but you got the point.
List<Foo> lFoo = new List<Foo>() { Foo1, Foo2, Foo3, Foo4 };
现在,我使用这个:
std::vector<Foo> vFoo;
vFoo.push_back(Foo1);
vFoo.push_back(Foo2);
vFoo.push_back(Foo3);
vFoo.push_back(Foo4);
但我觉得它很丑。有什么想法可以改进吗?有没有特殊的方式来实现它?
谢谢。
简短回答:否。这就是在 C++11 中添加对此类结构的语言支持的原因。如果您无法使用 C++11,则现有的 push_back
解决方案就足够了。
我使用 va_arg
构建自己的解决方案。
#include <cstdarg>
#include <iostream>
#include <vector>
template <typename T>
std::vector<T> initVector (int len, ...)
{
std::vector<T> v;
va_list vl;
va_start(vl, len);
v.push_back(va_arg(vl, T));
for (int i = 1; i < len; ++i)
v.push_back(va_arg(vl, T));
va_end(vl);
return v;
}
int main ()
{
std::vector<int> v = initVector<int> (7,702,422,631,834,892,104,772);
for(std::vector<int>::const_iterator it = v.begin() ; it != v.end(); ++it)
std::cout << *it << std::endl;
return 0;
}
如果您想要更多答案,请点击Doc Brown的链接。
您可以从数组初始化向量:
Foo[] initFoo = { Foo1, Foo2, Foo3, Foo4 };
std::vector<Foo> vFoo(initFoo, initFoo + 4);