zoukankan      html  css  js  c++  java
  • 转:C语言中的头文件可以自己写吗?

    转自:http://www.eefocus.com/computer00/blog/08-09/155791_9ebdc.html

    一些初学C语言的人,不知道头文件(*.h文件)原来还可以自己写的。

    只知道调用系统库函数时,要使用#i nclude语句将某些头文件包含进去。

    其实,头文件跟.C文件一样,是可以自己写的。

          头文件是一种文本文件,使用文本编辑器将代码编写好之后,以扩展名.h保存就行了。头文件中一般放一些重复使用的代码,例如函数声明,变量声明,常数定义,宏的定义等等。

         <>是标准库的头文件,""是非标准库的头文件.

          当使用#i nclude语句将头文件引用时,相当于将头文件中所有内容,复制到#i nclude处。

          为了避免因为重复引用而导致的编译错误,头文件常具有   

       #ifndef  LABEL
    #define LABEL
    //代码部分
    #endif

    的格式。其中,LABEL为一个唯一的标号,命名规则跟变量的命名规则一样。

          常根据它所在的头文件名来命名,例如,如果头文件的文件名叫做hardware.h那么可以这样使用:#ifndef   __HARDWARE_H__#define   __HARDWARE_H__  //代码部分#endif这样写的意思就是,如果没有定义__HARDWARE_H__,则定义__HARDWARE_H__,并编译下面的代码部分,直到遇到#endif

          这样,当重复引用时,由于__HARDWARE_H__已经被定义,则下面的代码部分就不会被编译了,这样就避免了重复定义。

          另外一个地方就是使用include时,使用引号与尖括号的意思是不一样的。

          使用引号(“”)时,首先搜索工程文件所在目录,然后再搜索编译器头文件所在目录。而使用尖括号(<>)时,刚好是相反的搜索顺序。

          假设我们有两个文件名一样的头文件hardware.h,但内容却是不一样的。

               一个保存在编译器指定的头文件目录下,我们把它叫做文件I

               另一个则保存在当前工程的目录下,我们把它叫做文件II

          如果我们使用的是#i nclude <hardware.h>,则我们引用到的是文件I

          如果我们使用的是#i nclude “hardware.h”,则我们引用的将是文件II

    笔者以前就遇到过一个同事问,为什么他修改了那个头文件里面的内容,好象跟没有修改一样?

    就是因为他有两个一样的头文件(就像我们刚描述的那样),他是使用#i nclude<hardware.h>引用的,而他修改时,却是当前工程所在的目录下的那个文件。

    比如建立我自己的头文件"myhead.h":

    编写代码如下:文件记事本编写后修改文件名和文件后缀为:myhead.h,放到源代码同一目录下。

    #ifndef   __MYHEAD_H__
    #define _MYHEAD_H 
    //代码部分
    #define TRUE 1
    #define FALSE 0
    #define OK 1
    #define ERROR 0
    #define INFEASIBLE -1
    #define OVERFLOW -2
    
    typedef int Status;
    
    #endif
  • 相关阅读:
    string
    luogu1419 寻找段落
    vijos2024 无向图最短路径
    [Tjoi2016&Heoi2016]排序
    Vijos1083 小白逛公园
    [ZJOI2007]矩阵游戏
    NOIP2015 信息传递
    [HAOI2006]受欢迎的牛
    luogu3834 【模板】可持久化线段树 1(主席树)
    luogu2625 豪华游轮
  • 原文地址:https://www.cnblogs.com/xingyunblog/p/4027447.html
Copyright © 2011-2022 走看看