如何以静态方式使用另一个 constexpr 数组初始化一个数组
How to initialise one array using another constexpr array in a static manner
我有一个这样的 constexpr
数组:
constexpr std::array<int, 4> BASES_TO_CHECK = { 8, 16, 32, 64 };
我想做类似的事情:
std::array<std::thread, BASES_TO_CHECK.size()> calc;
for(size_t i = 0; i<BASES_TO_CHECK.size(); ++i)
{
calc[i]=std::thread(calculate<BASES_TO_CHECK[i]>, std::ref(recordMap[BASES_TO_CHECK[i]]), std::ref(counterMap.at(BASES_TO_CHECK[i])), std::ref(done));
}
但是,由于变量被用作模板参数,所以这将不起作用。我最终这样做了:
std::array<std::thread, BASES_TO_CHECK.size()> calc = {
std::thread(calculate<BASES_TO_CHECK[0]>, std::ref(recordMap[BASES_TO_CHECK[0]]), std::ref(counterMap.at(BASES_TO_CHECK[0])), std::ref(done)),
std::thread(calculate<BASES_TO_CHECK[1]>, std::ref(recordMap[BASES_TO_CHECK[1]]), std::ref(counterMap.at(BASES_TO_CHECK[1])), std::ref(done)),
std::thread(calculate<BASES_TO_CHECK[2]>, std::ref(recordMap[BASES_TO_CHECK[2]]), std::ref(counterMap.at(BASES_TO_CHECK[2])), std::ref(done)),
std::thread(calculate<BASES_TO_CHECK[3]>, std::ref(recordMap[BASES_TO_CHECK[3]]), std::ref(counterMap.at(BASES_TO_CHECK[3])), std::ref(done))
};
这可行,但依赖于我不更改 BASES_TO_CHECK
中的元素数量,而无需手动更新初始化 calc
数组的代码部分。
template<std::size_t... i>
std::array<std::thread, BASES_TO_CHECK.size()> gen_impl(std::index_sequence<i...>) {
return {
std::thread(calculate<BASES_TO_CHECK[i]>,
std::ref(recordMap[BASES_TO_CHECK[i]]),
std::ref(counterMap.at(BASES_TO_CHECK[i])),
std::ref(done)
)...
};
}
auto calc = gen_impl(std::make_index_sequence<BASES_TO_CHECK.size()>{});
我有一个这样的 constexpr
数组:
constexpr std::array<int, 4> BASES_TO_CHECK = { 8, 16, 32, 64 };
我想做类似的事情:
std::array<std::thread, BASES_TO_CHECK.size()> calc;
for(size_t i = 0; i<BASES_TO_CHECK.size(); ++i)
{
calc[i]=std::thread(calculate<BASES_TO_CHECK[i]>, std::ref(recordMap[BASES_TO_CHECK[i]]), std::ref(counterMap.at(BASES_TO_CHECK[i])), std::ref(done));
}
但是,由于变量被用作模板参数,所以这将不起作用。我最终这样做了:
std::array<std::thread, BASES_TO_CHECK.size()> calc = {
std::thread(calculate<BASES_TO_CHECK[0]>, std::ref(recordMap[BASES_TO_CHECK[0]]), std::ref(counterMap.at(BASES_TO_CHECK[0])), std::ref(done)),
std::thread(calculate<BASES_TO_CHECK[1]>, std::ref(recordMap[BASES_TO_CHECK[1]]), std::ref(counterMap.at(BASES_TO_CHECK[1])), std::ref(done)),
std::thread(calculate<BASES_TO_CHECK[2]>, std::ref(recordMap[BASES_TO_CHECK[2]]), std::ref(counterMap.at(BASES_TO_CHECK[2])), std::ref(done)),
std::thread(calculate<BASES_TO_CHECK[3]>, std::ref(recordMap[BASES_TO_CHECK[3]]), std::ref(counterMap.at(BASES_TO_CHECK[3])), std::ref(done))
};
这可行,但依赖于我不更改 BASES_TO_CHECK
中的元素数量,而无需手动更新初始化 calc
数组的代码部分。
template<std::size_t... i>
std::array<std::thread, BASES_TO_CHECK.size()> gen_impl(std::index_sequence<i...>) {
return {
std::thread(calculate<BASES_TO_CHECK[i]>,
std::ref(recordMap[BASES_TO_CHECK[i]]),
std::ref(counterMap.at(BASES_TO_CHECK[i])),
std::ref(done)
)...
};
}
auto calc = gen_impl(std::make_index_sequence<BASES_TO_CHECK.size()>{});