循环固定大小的数组而不在C中定义其大小
一些示例代码来启动问题:
#define FOO_COUNT 5 static const char *foo[] = { "123", "456", "789", "987", "654" };
通常迭代的方式,如一个例子,如下:
int i = FOO_COUNT; while (--i >= 0) { printf("%s\n", foo[i]);
无论如何,如果没有明确地将人数统计为数字5,是否仍然可以做到这一点? 在将来,我可能会添加/删除元素,忘记更新数组的大小,从而破坏我的应用程序。
int i = sizeof(foo)/sizeof(foo[0]);
最后使用一个标记,例如NULL:
static const char *foo[] = { "123", "456", "789", "987", "654", NULL }; for (char *it = foo[0]; it != NULL; it++) { ... }
通常的方法是使用NULL结束数组并迭代直到你点击它。
是。
int i = sizeof(foo) / sizeof(char*);
注意:这仅适用于静态分配的数组。 它不适用于malloc
ed或new
ed数组。
size_t i = sizeof foo / sizeof *foo; // or sizeof foo / sizeof foo[0]
这将foo数组中的总字节数( sizeof foo
)除以单个元素( sizeof *foo
)中的字节数,从而给出数组中的元素数。
在C99中还有另一种方法,特别是如果你想要命名索引,允许实例化本地化等。
enum STRINGS { STR_THING1, STR_THING2, STR_THING3, STR_THING4, STR_WHATEVER, STR_MAX /* Always put this one at the end, as the counting starts at 0 */ /* this one will be defined as the number of elements */ } static const char *foo[STR_MAX] = { [STR_THING1] = "123", [STR_THING2] = "456", [STR_THING3] = "789", [STR_THING4] = "987", [STR_WHATEVER] = "OR Something else", };
通过使用命名的初始化程序,即使枚举值发生变化,程序仍然是正确的。
for (i = STR_THING1; i
或者使用指定索引的程序中的任何位置
printf("thing2 is %s\n", foo[STR_THING3]);
此技术可用于模拟资源包。 使用语言变体声明一个enum
和几个字符串数组,并在程序的其余部分使用指针。 简单快速(特别是在64位机器上,获取常量(字符串)的地址可能相对昂贵。编辑:sizeof foo / sizeof * foo技术仍然适用于此。
是。
的sizeof(富)/的sizeof(字符*)
是5。
对于某些应用程序, 尝试和Catch将工作。