检测不匹配的数组< - >枚举初始值设定项

use*_*733 6 c arrays enums initialization

使用C进行嵌入式编程时,我发现自己多次使用枚举和数组进行映射,因为它们速度快,内存效率高.

enum {
    ID_DOG = 0,
    ID_SPIDER,
    ID_WORM,
    ID_COUNT
};
int const NumberOfEyes[ID_COUNT] = {
    2,
    8,
    0
};
Run Code Online (Sandbox Code Playgroud)

问题是,有时在添加/删除项目时,我会犯错,枚举和数组不同步.如果初始化列表太长,编译器将检测它,但不是其他方式.

那么可靠和可移植的编译时检查初始化列表是否与数组的长度匹配?

Oli*_*rth 9

这可能是可以应用X宏的情况.

animals.x

X(DOG,    2)
X(SPIDER, 8)
X(WORM,   0)
Run Code Online (Sandbox Code Playgroud)

foo.c的

enum {
#define X(a,b) ID_##a,
#include "animals.x"
#undef X
};

int const numberOfEyes[] = {
#define X(a,b) b,
#include "animals.x"
#undef X
};
Run Code Online (Sandbox Code Playgroud)

这不仅保证了长度匹配,而且保证订单始终保持同步.


Jen*_*ens 3

像下面这样的编译时断言怎么样?(是的,还有更详细的 CT_ASSERT 宏;这是为了说明这个想法。)

#define CT_ASSERT(expr, name) typedef char name[(expr)?1:-1]

enum {
    ID_DOG = 0,
    ID_SPIDER,
    ID_WORM,
    ID_COUNT
};

int const NumberOfEyes[] = {
    2,
    8,
    0
};

CT_ASSERT (sizeof NumberOfEyes/sizeof *NumberOfEyes == ID_COUNT, foo);
Run Code Online (Sandbox Code Playgroud)

现在,当NumberOfEyes数组的元素多于或少于 时ID_COUNT,这将导致错误x.c:15: error: size of array 'foo' is negative。负数组维度是一种约束违规,任何 C 编译器都必须对其进行诊断。