首先,看看这个例子(我做了这件事,例如着想,这不是一个真正的程序):
whatever.h
#ifndef WHATEVER_H
#define WHATEVER_H
void fill(void);
#endif
main.c中
#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;
}
whatever.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;
与一个在main.c
,不应该是给我的错误? 如果它可以链接它们,怎么来的names
最终被NULL
在whatever.c
?
此外,如何做extern char **names;
从不同extern char *names[];
?
我使用Linux下的gcc版本4.5.1。
更新
为了进一步调查这个,我改变的定义, names
中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
)
基本上,它的意思是,海湾合作委员会已总算链接extern char **names;
在whatever.c
与names[0]
在main.c
!