1 / 8
文档名称:

C语言extern使用方法总结.doc

格式:doc   页数:8页
下载后只包含 1 个 DOC 格式的文档,没有任何的图纸或源代码,查看文件列表

如果您已付费下载过本站文档,您可以点这里二次下载

分享

预览

C语言extern使用方法总结.doc

上传人:012luyin 2016/6/1 文件大小:0 KB

下载得到文件列表

C语言extern使用方法总结.doc

文档介绍

文档介绍:extern 使用方法总结! 作者: VIP 用户提交日期: 2007-5-16 20:53:00 Extern 的问题在于不知道这个关键词出现的时候到底是声明还是定义。谨记:声明可以多次,定义只能一次。函数的声明 extern 关键词是可有可无的, 因为函数本身不加修饰的话就是 extern 的。但是引用的时候一样是需要声明的。而全局变量在外部使用声明时, extern 关键词是必须的, 如果变量无 extern 修饰且没有显式的初始化, 同样成为变量的定义, 因此此时必须加 extern , 而编译器在此标记存储空间在执行时加载如内存并初始化为 0。而局部变量的声明不能有 extern 的修饰, 且局部变量在运行时才在堆栈部分分配内存。引用性声明、定义性声明强符号、弱符号出现在 linux 的 gcc 链接分析中,可以加深链接的理解。全局变量或函数本质上讲没有区别, 函数名是指向函数二进制块开头处的指针。而全局变量是在函数外部声明的变量。函数名也在函数外,因此函数也是全局的。在使用中,要形成一种风格。头文件首先说下头文件,其实头文件对计算机而言没什么作用,她只是在预编译时在#include 的地方展开一下,没别的意义了,其实头文件主要是给别人看的。我做过一个实验,将头文件的后缀改成 ,然后在引用该头文件的地方用#include"" 编译,链接都很顺利的过去了,由此可知,头文件仅仅为阅读代码作用,没其他的作用了! 不管是 C 还是 C++ , 你把你的函数, 变量或者结构体, 文件里。然后编译成 lib,dll,obj,.o 等等,然后别人用的时候最基本的 gcc |obj|dll|lib 等等。但对于我们程序员而言,他们怎么知道你的 lib,dll... 里面到底有什么东西?要看你的头文件。你的头文件就是对用户的说明。函数,参数,各种各样的接口的说明。那既然是说明,那么头文件里面放的自然就是关于函数,变量,类的“声明”了。记着,是“声明”,不是“定义”。那么,我假设大家知道声明和定义的区别。所以,最好不要傻嘻嘻的在头文件里定义什么东西。比如全局变量: #ifndef _XX_ #define _XX_ int A; #endif 那么,很糟糕的是,这里的 int A 是个全局变量的定义,所以如果这个头文件被多次引用的话,你的 A 会被重复定义显然语法上错了。只不过有了这个#ifndef 的条件编译, 所以能保证你的头文件只被引用一次,不过也许还是会岔子,但若多个 c 文件包含这个头文件时还是会出错的,因为宏名有效范围仅限于本 c 源文件,所以在这多个 c 文件编译时是不会出错的,但在链接时就会报错,说你多处定义了同一个变量, Linking... : error LNK2005: "int glb" ( ?glb@***@3HA ) already defined in Debug/ : fatal error LNK1169: one or more multiply defined symbols found 注意!!! extern 这个关键字真的比较可恶,在声