通常情况下定义数组都是顶一个什么类型的数组然后下标或者脚标就是从 0 开始 ++
int array[10] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
但是用 0-N 这种整形数字做下标可读性非常不高,如果这个数组里保存的数据比较复杂,那么这种硬编码的下标方式非常的危险。所以这里通常都使用枚举变量作为下标来访问数组。如下
static char* language_type_data[] = {
"Chinese",
"German",
"American"
};
typedef enum OS_APP_LANGUAGE_TYPE_E
{
OS_APP_LANGUAGE_TYPE_EN = 0,
OS_APP_LANGUAGE_TYPE_DE = 1,
OS_APP_LANGUAGE_TYPE_US = 2,
OS_APP_LANGUAGE_TYPE_UNKNOWN,
}OS_APP_LANGUAGE_TYPE_E;
OS_APP_LANGUAGE_TYPE_E os_app_language_type_data;
这里使用 language_type_data[OS_APP_LANGUAGE_TYPE_EN ]来访问数组第一个成员。这样写可读性很高,而且后期可以继续添加数组的成员,枚举的成员,且代码可以用循环判断来写,这样以后增加新成员只需要在枚举和数组上增加变量既可。但这段代码也有隐藏的问题。看似可读性高的代码其实也是硬编码作为脚标,如果在输入数据时候数组和枚举的顺序有一些变化,就会出现 bug,且这个 bug 很难被发现。且这个枚举是作为 SDK 提供给上层,且你的代码不公开,这样会出现很大问题。
为了避免这种隐患可以在定义数组时候使用枚举作为数组的下标,这样即使数据输入混乱,但是只要数组定义时候枚举下标定义和数组成员可以对应正确就可以避免这种错误。代码如下:
static char* language_type_data[] = {
[OS_APP_LANGUAGE_TYPE_EN] = "Chinese",
[OS_APP_LANGUAGE_TYPE_DE] = "German",
[OS_APP_LANGUAGE_TYPE_US] = "American"
};
使用 language_type_data[OS_APP_LANGUAGE_TYPE_EN]来访问数组,这样技术数据顺序混乱也不会出现问题。
https://www.cnblogs.com/cxh110/p/9316705.html