我的问题是什么时候一个函数应该引用extern关键字在C。

我看不出什么时候应该在实践中使用这种方法。当我在编写程序时,我使用的所有函数都可以通过我包含的头文件获得。那么,extern访问头文件中没有公开的内容为什么有用呢?

我可能在想extern如何不正确地工作,如果是这样,请纠正我。

也. .当它是头文件中没有关键字的默认声明时,您是否应该扩展某些内容?


当前回答

Extern告诉编译器这个数据是在某个地方定义的,并且将与链接器连接。

在这里的回答和与一些朋友的交谈的帮助下,这里有一个使用extern的实际示例。

例1 -显示一个陷阱:

stdio . h:

int errno;

myCFile1.c:

#include <stdio.h>

// Code using errno...

myCFile2.c:

#include <stdio.h>

// Code using errno...

如果myCFile1。o和myCFile2。O是链接的,每个c文件都有单独的errno副本。这是一个问题,因为相同的errno应该在所有链接的文件中可用。

例2 -修复。

stdio . h:

extern int errno;

stdio.c:

int errno;

myCFile1.c:

#include <stdio.h>

// Code using errno...

myCFile2.c:

#include <stdio.h>

// Code using errno...

如果两者都是myCFile1。o和MyCFile2。O由链接器链接,它们都指向相同的errno。因此,用extern解决实现问题。

其他回答

前面已经说过,extern关键字对于函数来说是多余的。

对于跨编译单元共享的变量,应该在头文件中使用extern关键字声明它们,然后在单个源文件中定义它们,不使用extern关键字。为了最佳实践,单个源文件应该是共享头文件名称的文件。

当你在不同的dll或lib上定义该函数时,编译器会根据链接器来查找它。典型的情况是当你从OS API调用函数时。

Extern告诉编译器这个数据是在某个地方定义的,并且将与链接器连接。

在这里的回答和与一些朋友的交谈的帮助下,这里有一个使用extern的实际示例。

例1 -显示一个陷阱:

stdio . h:

int errno;

myCFile1.c:

#include <stdio.h>

// Code using errno...

myCFile2.c:

#include <stdio.h>

// Code using errno...

如果myCFile1。o和myCFile2。O是链接的,每个c文件都有单独的errno副本。这是一个问题,因为相同的errno应该在所有链接的文件中可用。

例2 -修复。

stdio . h:

extern int errno;

stdio.c:

int errno;

myCFile1.c:

#include <stdio.h>

// Code using errno...

myCFile2.c:

#include <stdio.h>

// Code using errno...

如果两者都是myCFile1。o和MyCFile2。O由链接器链接,它们都指向相同的errno。因此,用extern解决实现问题。

Extern更改链接。使用关键字,函数/变量被假定在其他地方可用,解析被推迟到链接器。

函数上的extern和变量上的extern是不同的。

对于变量,它不实例化变量本身,即不分配任何内存。这得在别的地方做。因此,如果您想从其他地方导入变量,这是很重要的。

对于函数,这只告诉编译器链接是extern。因为这是默认值(使用关键字static表示函数没有使用extern链接绑定),所以不需要显式地使用它。

在其他源文件中实际定义的函数应该只在头文件中声明。在这种情况下,在头文件中声明原型时应该使用extern。

大多数情况下,你的函数会是以下其中之一(更像是最佳实践):

静态(不是静态的普通函数 可见的外部。c文件) 静态内联(内联来自。c或。h 文件) 的头中的声明 下一类(见下文)) [no关键字whatever](正常 用于访问的函数 外面的声明)