我有一个数组,其大小是使用编译时常量(在我的情况下为预处理器#define
)设置的。我需要在编译时使用连续的数字对其进行初始化。我该怎么办?
简化示例:
#define ARR_SZ 5
struct C {
C(int a) : a(a) {}
int a;
};
C arr[ARR_SZ] = {{0},{1},{2},{3},{4}}; // This needs to adapt to any number
我可以使用C ++ 11,但不能使用较新的版本(尽管即使我不能在本项目中使用它们,我也有兴趣学习较新的技术)
答案 0 :(得分:3)
C ++ 14代码(由于std::integer_sequence
):
#include <type_traits>
#include <array>
#define ARR_SZ 5
struct C {
C(int a) : a(a) {}
int a;
};
template<int ...Is>
auto make_C_arr(std::integer_sequence<int, Is...>) -> std::array<C, sizeof...(Is)> {
return {{ {Is}... }};
}
auto arr = make_C_arr(std::make_integer_sequence<int, ARR_SZ>{});
int main () {
}
std::integer_sequence
等可在C ++ 11中实现,但是如注释中所述,因此将标准版本替换为自制的版本将提供C ++ 11特定的解决方案。
答案 1 :(得分:1)
由于注释部分提到了boost,因此这是另一个基于Boost.PP的完全不同的解决方案。它也完全是C ++ 03。
#include <boost/preprocessor/repetition/repeat.hpp>
#include <boost/preprocessor/punctuation/comma_if.hpp>
#define ARR_SZ 5
struct C {
C(int a) : a(a) {}
int a;
};
#define INIT(z, n, d) BOOST_PP_COMMA_IF(n) C(n)
C arr[ARR_SZ] = { BOOST_PP_REPEAT(ARR_SZ, INIT, ?) };
int main () {
}
BOOST_PP_REPEAT
将扩展为INIT(z, 0, ?) ... INIT(z, 4, ?)
。 z
与我们的目标无关,?
令牌只是一个占位符。由于INIT
依次将C(n)
的{{1}}从0扩展到4(以逗号分隔),因此我们得到了用于常规C样式数组的初始化器。