问题描述
我听说默认情况下,其中的函数称为“外部”。因此,根据此功能范围应该在整个项目内部,不是吗?我相信还没有看到。我只想知道默认情况下在整个项目文件中它是否真正可见?
文章链接:https://www.geeksforgeeks.org/understanding-extern-keyword-in-c/
它说:
“首先,让我们考虑一下在函数中使用extern的情况。事实证明,在声明或定义函数时,会隐式假定extern关键字。在编写时。
int foo(int arg1,char arg2);
编译器将其视为:extern int foo(int arg1,char arg2);
由于extern关键字将功能的可见性扩展到整个程序,因此该功能可以在整个程序的任何文件中的任何位置使用(调用),只要这些文件包含该功能的声明即可。 (在函数声明到位后,编译器知道该函数的定义存在于其他地方,并且可以继续编译该文件)。这就是外部和功能的全部。 “
解决方法
您可以在C11标准草案N1570的“ 6.2.2标识符的链接”部分中找到此内容。
它说:
,如果函数的标识符声明没有存储类说明符,则其链接 完全确定是否与使用存储类说明符extern声明的一样。
对于函数定义,extern
修饰符的使用是可选的。但是,许多C开发人员将其用作样式问题,以指示阅读源代码的人没有必要在同一文件中查找该函数的定义。
是的,所有函数(如果没有其他修饰符)都是隐式外部的。您可以使用static修饰符对其进行更改,从而使该功能仅对所写入的文件可见。另一个非常常见的用途是extern inline,它使内联函数对其他文件可见,而不仅仅是对其定义的模块。
,是的,除非文件声明为static
,否则C默认情况下是filescope中新命名对象的全局可见性。
请注意,extern
并非 表示全局可见性。这意味着先前声明的可见性或(如果没有这样的声明)则是全局可见性。
extern
在非静态函数上是可选的(对于新的(C> = C11)内联函数有某些特殊含义),但是对于filescope变量声明,有时需要区分声明和临时定义。
示例:
void globalFunc(void);
void globalFunc(void){ }
static void fileLocalFunc(void);
void fileLocalFunc(void){ } //ok,file-local because the previous declaration was file-local
static void another_fileLocalFunc(void);
extern void another_fileLocalFunc(void){ } //extern is optional for functions
static int fileLocal_variable;
extern int fileLocal_variable; //ok,file-local,because the previous declaration was file-local
//some noncompiling stuff:
#if 0 || CONFLICTING_FUNC_DECLARATIONS0
extern void conflictingFuncDeclarations0(void);
static void conflictingFuncDeclarations0(void);
#endif
#if 0 || CONFLICTING_FUNC_DECLARATIONS1
void conflictingFuncDeclarations1(void);
static void conflictingFuncDeclarations1(void);
#endif
#if 0 || CONFLICTING_VAR_DECLARATIONS0
int conflictingVarDeclarations0;
static int conflictingVarDeclarations0;
#endif
如果您使用的是POSIX系统,则可以将翻译单元编译为目标(*.o
)文件,然后在其上使用nm
实用程序查看其导出的名称(或尝试使用的名称)。导入)。