我有从单个超类型派生的不同类型的对象。我想知道在这样的循环范围内使用std::initializer
列表是否有任何缺点:
for(auto object: std::initializer_list<Object *>{object1, object2, object3}) {
}
它是完全正常和有效还是使用阵列会更好?对我来说,std::array
解决方案似乎对编译器更具限制性,并且明确说明大小存在缺点:
for(auto object: std::array<Object*, 3>{object1, object2, object3}) {
}
是否有任何其他或更好的方法迭代明确给定的对象列表?
答案 0 :(得分:10)
无需在循环中使用详细std::initializer_list
#include <iostream>
#include <initializer_list>
struct B { virtual int fun() { return 0; } };
struct D1 : B { int fun() { return 1; } };
struct D2 : B { int fun() { return 2; } };
int main()
{
D1 x;
D2 y;
B* px = &x;
B* py = &y;
for (auto& e : { px, py })
std::cout << e->fun() << "\n";
}
如果您想在不定义px
和py
的情况下即时执行此操作,您确实可以在循环中使用std::initializer_list<B*>{ &x, &y }
。
答案 1 :(得分:8)
你可以简单地写
for(auto object : {object1, object2, object3}) {
// work
}