首先,看这个例子(我为了例子而编造了这个,它不是一个真正的程序):
随便什么.h
#ifndef WHATEVER_H
#define WHATEVER_H
void fill(void);
#endif
主程序
#include <stdio.h>
#include "whatever.h"
char *names[10] = {NULL};
int main()
{
int i;
fill();
for (i = 0; i < 10; ++i)
printf("%s\n", names[i]);
return 0;
}
随便什么.c
#include "whatever.h"
extern char **names;
void fill(void)
{
int i;
for (i = 0; i < 10; ++i)
names[i] = "some name";
}
当我使用以下方法制作这个程序时:
gcc -o test main.c whatever.c -Wall -g
我没有收到任何错误或警告。但是,当我运行程序时,我看到 ,fill
实际上names
是NULL
. 如果whatever.c
我改变
extern char **names;
到
extern char *names[];
那么一切都很好。
谁能解释为什么会这样?如果 gcc 无法extern char **names;
与 in链接,main.c
它不应该给我一个错误吗?如果它可以链接它们,为什么names
最终会NULL
在whatever.c
?
另外,与 有何extern char **names;
不同extern char *names[];
?
我在 Linux 下使用 gcc 版本 4.5.1。
更新
为了进一步研究这一点,我将names
in的定义更改main.c
为:
char *names[10] = {"1", "2", "3", "4", "5", "6", "7", "8", "9", "10"};
(保留extern char **names;
)whatever.c
和gdb
,我可以看到它names
具有价值。如果我将该值转换为char *
并打印它,它会给我"1"
. (注意,不是*names
,"1"
而是(char *)names
)
基本上,这意味着 gcc 以某种方式设法与inextern char **names;
链接!whatever.c
names[0]
main.c