修改成员初始化器列表

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