用递增的数字初始化一个编译时常量大小的数组

时间:2019-01-21 09:14:05

标签: c++ c++11

我有一个数组,其大小是使用编译时常量(在我的情况下为预处理器#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,但不能使用较新的版本(尽管即使我不能在本项目中使用它们,我也有兴趣学习较新的技术)

2 个答案:

答案 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样式数组的初始化器。