c语言头文件的建立与使用.pdfVIP

  1. 1、本文档共11页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
嵌入式c 语言头文件的建立与使用 如何正确编写C 语言头文件和与之相关联的c 源程序文件,这 首先就要了解它们的各自功能。要理解C 文件与头文件(即.h)有什么 不同之处,首先需要弄明白编译器的工作过程。 一般说来编译器会做以下几个过程: 1.预处理阶段 2.编译阶段,首先编译成纯汇编语句,再将之汇编成跟CPU 相关的二进 制码,生成各个目标文件(.obj 文件) 3.连接阶段,将各个目标文件中的各段代码进行绝对地址定位,生成跟特 定平台相关的可执行文件。 编译器在编译时是以C 文件为单位进行的,也就是说如果你的项目 中一个C 文件都没有,那么你的项目将无法编译,连接器是以目标文件 为单位,它将一个或多个目标文件进行函数与变量的重定位,生成最终 的可执行文件。 为了生成一个最终的可执行文件,就需要一些目标文件,也就是首先 要有C 文件,而这些C 文件中又需要一个main ()函数作为可执行程序 的入口,那么我们就从从这一个C 文件入手,引入头文件概念。 假定这个C 文件内容如下: #include stdio.h #include mytest.h int main(int argc,char **argv) { test = 25; printf(test %d\n,test); } 头文件mytest.h包含如下内容: int test; 现在以这个例子来讲解编译器的工作: 1.预处理阶段:编译器以C 文件作为一个单元,首先读这个 C 文件,发 现第一句与第二句是包含一个头文件,就会在所有搜索路径中寻找这两 个文件,找到之后,就会将相应头文件中的宏,变量,函数声明,嵌套 的头文件包含等,进行依赖关系检测,并进行宏替换,看是否有重复声 明与定义的情况发生,最后将那些文件中所有的东东全部扫描进这个当 前的C 文件中,形成一个中间C 文件 2.编译阶段,在上一步中相当于将第二个头文件中的test 变量扫描进了一 个中间C 文件,那么test 变量就变成了这个文件中的一个全局变量,此 时就将所有这个中间C 文件的所有变量,函数分配空间,将各个函数编 译成二进制码,按照特定目标文件格式生成目标文件,在这种格式的目 标文件中进行各个全局变量,函数的符号描述,将这些二进制码按照一 定的标准组织成一个目标文件 3.连接阶段,将上一步成生的各个目标文件,根据一些参数,连接生成最 终的可执行文件,主要的工作就是重定位各个目标文件的函数,变量等, 相当于将个目标文件中的二进制码按一定的规范合到一个文件中。 再回到 C 文件与头文件各写什么内容的话题上:一般都在头件中进 行函数声明,变量声明,宏声明,结构体声明呢?而在C 文件中去进行 变量定义,函数实现。理论上来说C 文件与头文件里的内容,只要是C 语 言所支持的,无论写什么都可以的,比如你在头文件中写函数体,只要 在任何一个C 文件包含此头文件就可以将这个函数编译成目标文件的 一部分(编译是以C 文件为单位的,如果不在任何 C 文件中包含此头文 件的话,这段代码就形同虚设),你可以在C 文件中进行函数声明,变量 声明,结构体声明,这也不成问题!!!那为何一定要分成头文件与 C 文 件呢?又为何一般都在头件中进行函数声明,变量声明,宏声明,结构 体声明呢?而在C 文件中去进行变量定义,函数实现呢?原因如下: 1.如果在头文件中实现一个函数体,那么如果在多个C 文件中引用它,而 且又同时编译多个C 文件,将其生成的目标文件连接成一个可执行文件, 在每个引用此头文件的C 文件所生成的目标文件中,都有一份这个函数 的代码,如果这段函数又没有定义成局部函数,那么在连接时,就会发 现多个相同的函数,就会报错 2.如果在头文件中定义全局变量,并且将此全局变量赋初值,那么在多个 引用此头文件的C 文件中同样存在相同变量名的拷贝,关键是此变量被 赋了初值,所以编译器就会将此变量放入DATA 段,最终在连接阶段, 会在 DATA 段中存在多个相同的变量,它无法将这些变量统一成一个变 量,也就是仅为此变量分配一个空间,而不是多份空间,假定这个变量 在头文件没有赋初值,编译器就会将之放入 BSS 段,连接器会对BSS 段 的多个同名变量仅分配一个存储空间 3.如果在 C 文件中声明宏,结构体,函数等,那么我要在另一个C 文件 中引用相应的宏,结构体,就必须再做一次重复的工作,如果我改了一 个 C 文件中的一个声明,那么又忘了改其它C 文件中的声明,这不就出 了大问题

文档评论(0)

rijindj + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档