所以我所拥有的是一个文件 main.c ,其中包含我创建的 utils.h 的头文件,其中包含我的源文件中函数的前向引用 utils.c
我有一个函数接受一个字符串数组作为参数,并将其作为菜单打印出来:
void showMenu(const char *menu[])
{
int menulen = sizeof(menu)/sizeof(*menu);
int i;
for(i = 0; i < menulen; i++)
{
printf("[%d] .. %s\n", (i+1), menu[i]);
}
}
我只是叫这个函数:
const char *menu[] =
{
"Customers",
"Orders",
"Products"
};
int main(void)
{
showTitle("Customer Orders System");
int menulen = sizeof(menu)/sizeof(*menu);
showMenu(menu);
getch();
}
我的 showMenu 函数正在计算数组的长度,然后遍历它,打印字符串。当函数在 main.c 时,这曾经有用,但是我需要在单独的文件中组织这个项目。
现在计算的长度为1.经过一些调试后,我认为这是一个与指针相关的问题,但我似乎解决了它。调用后 showMenu 的参数类型为
const char** menu
只有原始数组的第一个元素。
我尝试引用该参数,同时向它传递一个数组的指针 奇怪的是,同一行代码在main函数中起作用。 我真的不想通过在函数中添加一个数组参数来解决这个问题。
非常感谢任何帮助。
答案 0 :(得分:10)
这是因为当传递给像你这样的函数时,数组将衰减成指向第一个元素的指针,并且没有关于元素数量的信息。在声明数组的范围内,此衰减尚未发生,因此sizeof
可以正常工作。
您必须添加数组长度作为额外参数,或者确保数组以适当的 sentinel 值终止。一个流行的这样的值是NULL
,即你确保最后一个有效索引包含一个字符串指针,其值为NULL
,然后表示“没有更多的数据,停止”:
const char *menu[] =
{
"Customers",
"Orders",
"Products",
NULL /* This is a sentinel, to mark the end of the array. */
};