正在初始化 std::array 个非默认可构造元素?
Initializing an std::array of non-default-constructible elements?
假设类型 foo_t
具有命名构造函数惯用语 make_foo()
。现在,我想要恰好有 123 个 foo,不多也不少。所以,我正在考虑 std::array<foo_t, 123>
。现在,如果 foo_t
是可默认构造的,我会写:
std::array<foo_t, 123> pity_the_foos;
std::generate(
std::begin(pity_the_foos), std::end(pity_the_foos),
[]() { return make_foo(); }
);
Bob 是我叔叔,对吧?不幸的是... foo_t
没有默认的构造函数。
那么我该如何初始化我的数组呢?我是否需要使用一些可变参数模板扩展巫术?
注意: 如果有帮助,答案可以使用 C++11、C++14 或 C++17 中的任何内容。
平常。
template<size_t...Is>
std::array<foo_t, sizeof...(Is)> make_foos(std::index_sequence<Is...>) {
return { ((void)Is, make_foo())... };
}
template<size_t N>
std::array<foo_t, N> make_foos() {
return make_foos(std::make_index_sequence<N>());
}
假设类型 foo_t
具有命名构造函数惯用语 make_foo()
。现在,我想要恰好有 123 个 foo,不多也不少。所以,我正在考虑 std::array<foo_t, 123>
。现在,如果 foo_t
是可默认构造的,我会写:
std::array<foo_t, 123> pity_the_foos;
std::generate(
std::begin(pity_the_foos), std::end(pity_the_foos),
[]() { return make_foo(); }
);
Bob 是我叔叔,对吧?不幸的是... foo_t
没有默认的构造函数。
那么我该如何初始化我的数组呢?我是否需要使用一些可变参数模板扩展巫术?
注意: 如果有帮助,答案可以使用 C++11、C++14 或 C++17 中的任何内容。
平常。
template<size_t...Is>
std::array<foo_t, sizeof...(Is)> make_foos(std::index_sequence<Is...>) {
return { ((void)Is, make_foo())... };
}
template<size_t N>
std::array<foo_t, N> make_foos() {
return make_foos(std::make_index_sequence<N>());
}