修改成员初始化器列表
Modifying a member initializer list
我有一些代码可以有效地减少到
#include <vector>
class A {
std::vector<int> m_sizes;
public:
A(std::initializer_list<int> const& sizes) : m_sizes(sizes) {}
};
class B {
A m_a;
public:
B(int size_front, int size_back, std::initializer_list<int> const& sizes) : m_a({ size_front, sizes, size_back }) {}
};
编译器抱怨没有 A::A
的实例与参数列表匹配。
有什么方法可以将 { int, std::initializer_list<int>, int }
展平为 std::initializer_list<int>
还是我必须给 A
一个额外的构造函数来处理这种情况?如果我无法修改 A
class 怎么办?
您尝试执行的操作是不可能的:initializer_list<T>
必须从 T
类型的项目列表构造,其计数在编译时已知。在中间插入现有列表不起作用。
您可以通过添加一个直接接受 vector<int>
的构造函数重载来解决这个问题,然后 转发 调用它:
class A {
std::vector<int> m_sizes;
public:
A(const std::vector<int>& sizes) : m_sizes(sizes) {}
A(std::initializer_list<int> const& sizes) : A(std::vector(sizes)) {}
};
class B {
A m_a;
std::vector<int> frame(int size_front, int size_back, std::initializer_list<int> const& sizes) {
std::vector res;
res.push_back(size_front);
std::copy(sizes.begin(), sizes.end(), std::back_inserter(res));
res.push_back(size_back);
return res;
}
public:
B(int size_front, int size_back, std::initializer_list<int> const& sizes) : m_a(frame(size_front, size_back, sizes)) {}
};
我有一些代码可以有效地减少到
#include <vector>
class A {
std::vector<int> m_sizes;
public:
A(std::initializer_list<int> const& sizes) : m_sizes(sizes) {}
};
class B {
A m_a;
public:
B(int size_front, int size_back, std::initializer_list<int> const& sizes) : m_a({ size_front, sizes, size_back }) {}
};
编译器抱怨没有 A::A
的实例与参数列表匹配。
有什么方法可以将 { int, std::initializer_list<int>, int }
展平为 std::initializer_list<int>
还是我必须给 A
一个额外的构造函数来处理这种情况?如果我无法修改 A
class 怎么办?
您尝试执行的操作是不可能的:initializer_list<T>
必须从 T
类型的项目列表构造,其计数在编译时已知。在中间插入现有列表不起作用。
您可以通过添加一个直接接受 vector<int>
的构造函数重载来解决这个问题,然后 转发 调用它:
class A {
std::vector<int> m_sizes;
public:
A(const std::vector<int>& sizes) : m_sizes(sizes) {}
A(std::initializer_list<int> const& sizes) : A(std::vector(sizes)) {}
};
class B {
A m_a;
std::vector<int> frame(int size_front, int size_back, std::initializer_list<int> const& sizes) {
std::vector res;
res.push_back(size_front);
std::copy(sizes.begin(), sizes.end(), std::back_inserter(res));
res.push_back(size_back);
return res;
}
public:
B(int size_front, int size_back, std::initializer_list<int> const& sizes) : m_a(frame(size_front, size_back, sizes)) {}
};