首页 > 编程 > C++ > 正文

C++头文件中加#ifndef #define #endif的作用浅析

2019-11-08 00:52:03
字体:
来源:转载
供稿:网友

通常,在做一个项目工程时,往往有很多很多的文件,而由于面向对象的特性,为实现模块化和编写出稳定的、可读性高、易维护的、健壮的代码,往往将类封装起来。假如某个头文件被多个文件包含使用,当把这些文件编译链接成一个可执行文件时,就会出现大量重复定义的错误,而在头文件中加#ifndef #def #endif能避免头文件的重定义。 例:如编写头文件complex.h 在头文件开头写上两行:

#ifndef _COMPLEX_H_ //命名规则一般讲头文件用大写字母并将'.'改成下划线'_',且在最前和最后都加上'_'#define _COMPLEX_H_ //Code Block#endif

这样一个工程中有两个文件都包含complex.h时,就不会出现重定义的错误了。

原因:第一次包含complex.h时由于没有定义COMPLEX_H, if条件为真,这样便会执行代码块,而当第二次包含complex.h时,由于已经定义便不会执行#ifndef COMPLEX_H #define COMPLEX_H与#endif之间的代码块。如此防止重复编译(重复定义)。

在编写程序时,我觉得不管大小,封装类文件时都加上这个宏定义,当然,现在很多的IDE会自动生成这三行代码。

对应的还有:

#ifdef //Code Block#endif

可用于条件编译,这在代码的测试和调试中会用得到,有时用这种条件编译比用输出语句简洁的多。


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选