鱼C论坛

 找回密码
 立即注册
查看: 1536|回复: 0

[技术交流] 【转载】c,c++里面,头文件里面的ifndef /define/endif的作用

[复制链接]
发表于 2019-11-28 09:54:45 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
原文链接:https://blog.csdn.net/yapingmcu/article/details/8027473

例如:要编写头文件test.h

         在头文件开头写上两行:

          #ifndef _TEST_H

          #define _TEST_H//一般是文件名的大写

         ············

         ············

         头文件结尾写上一行:

          #endif

    1.比如你有两个C文件,这两个C文件都include了同一个头文件。而编译时,这两个C文件要一同编译成一个可运行文件,于是问题来了,大量的声明冲突。

例如:

假设你的工程里面有4个文件,分别是a.cpp,b.h,c.h,d.h。  
a.cpp的头部是:  
#include   "b.h "  
#include   "c.h "  
b.h和c.h的头部都是:  
#include   "d.h "  
而d.h里面有class   D的定义。  
这样一来,  
编译器编译a.cpp的时候,先根据#include   "b.h "去编译b.h这个问题,再根据b.h里面的#include   "d.h ",去编译d.h的这个文件,这样就把d.h里面的class   D编译了;  
然后再根据a.cpp的第二句#include   "c.h ",去编译c.h,最终还是会找到的d.h里面的class   D,但是class   D之前已经编译过了,所以就会报重定义错误。 加上ifndef/define/endif,就可以防止这种重定义错误。


所以还是把头文件的内容都放在#ifndef和#endif中吧。  
不管你的头文件会不会被多个文件引用,你都要加上这个。  
一般格式是这样的:   
#ifndef   <标识 >   
#define   <标识 >   
......   
......   
#endif   <标识 >  
在理论上来说可以是自由命名的,但每个头文件的这个“标识”都应该是唯一的。标识的命名规则一般是头文件名全大写,前后加下划线,并把文件名中的“.”也变成下划线,如:stdio.h   
#ifndef   _STDIO_H_   
#define   _STDIO_H_   
......   
#endif  


2.在#ifndef中定义变量出现的问题(一般不定义在#ifndef中)。   
#ifndef   AAA   
#define   AAA   
...   
int   i;   
...   
#endif   
里面有一个变量定义在vc中链接时就出现了i重复定义的错误,而在c中成功编译。   
原因:   
(1).当你第一个使用这个头的.cpp文件生成.obj的时候,int   i   在里面定义了当另外一个使用这个的.cpp再次[单独]生成.obj的时候,int   i   又被定义然后两个obj被另外一个.cpp也include   这个头的,连接在一起,就会出现重复定义.   (2).把源程序文件扩展名改成.c后,VC按照C语言的语法对源程序进行编译,而不是C++。在C语言中,若是遇到多个int   i,则自动认为其中一个是定义,其他的是声明。

  
(3).C语言和C++语言连接结果不同,可能(猜测)时在进行编译的时候,C++语言将全局变量默认为强符号,所以连接出错。C语言则依照是否初始化进行强弱的判断的。  
(参考解决方法:   
(1).把源程序文件扩展名改成.c。   
(2).推荐解决方案:   .h中只声明   extern   int   i;  
        在.cpp中定义   
#ifndef   __X_H__   
#define   __X_H__   
extern   int   i;   
#endif   //__X_H__   int   i;   
注意问题:变量一般不要定义在.h文件中。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-10-5 01:16

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表