#ifndef 和 #pragma once 防止头文件被一个源文件重复包含

2023-05-16

参考:#ifndef详解
#pragma once

1、#ifndef…#define…#endif

#ifndef 是"if not defined"的简写,是预处理功能(宏定义、文件包含、条件编译)当中的条件编译,可以根据是否已经定义了一个变量来进行分支选择,其作用是:

1、防止头文件的重复包含和编译;

2、便于程序的调试和移植;

一般地,假如有一个C源文件(如sourcefile.cpp),它包含两个头文件(如headfile_1.h和headfile_2.h),而头文件headfile_2.h又包含了headfile_1.h,则最终的效果是该源文件包含了两次headfile_1.h。如果你在头文件里定义了结构体或者类类型,那么问题来了,编译时将会报重复定义的错误。
加上条件编译"ifndef"则问题可解决。在headfile_1.h中加上条件编译。

小结:还是把头文件的内容都放在#ifndef和#endif中吧。不管你的头文件会不会被多个文件引用,你最好都加上这个。一般格式是这样的:

#ifndef <标识>
#define <标识>

......

......

#endif

<标识>在理论上来说是可以自由命名的,但每个头文件的这个“标识”都应该是唯一的。标识的明明规则一般是头文件名全大写,前面加下划线,并把文件名中的"."也变成下划线,如:stdio.h

#ifndef _STDIO_H
#define _STDIO_H

......

......

#endif

注意:#ifndef起到的效果是防止一个源文件多次包含同一个头文件,而不是防止两个源文件包含同一个头文件。事实上,防止同一头文件被两个不同的源文件包含这种要求本身就是不合理的,头文件存在的价值就是被不同的源文件包含。

2、#pragma once

一般是windows上的用法

#ifndef 可防重复包含可防内容重复,可对一段代码做声明,但防不住宏名撞车,编译大型项目时,ifndef会使得编译时间相对较长,但不怎么受编译器限制,编译器每次都需要打开头文件才能判定是否有重复定义。

#pragma只保证物理文件不会被包含多次,不可以对一段代码做声明,但不用担心宏名冲突。不支持跨平台。

#pragma once 方式产生于#ifndef之后,因此很多人可能甚至没有听说过。目前看来#ifndef更受到推崇。因为#ifndef受C/C++语言标准的支持,不受编译器的任何限制。

而#pragma once方式却不受一些较老版本的编译器支持,一些支持了的编译器又打算去掉它,所以它的兼容性可能不够好。

一般而言,当程序员听到这样的话,都会选择#ifndef方式,为了努力使得自己的代码“存活”时间更久,通常宁愿降低一些编译性能,这是程序员的个性。

程序员:努力使得自己的代码存活的更久

两者格式为

#pragma once (意为pragram once 只编译一次)
//…

#ifndef 
#define 
#endif

一定不要兼用两者:兼有不了两者优点,反而会让一些不懂的人徒增困惑

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

#ifndef 和 #pragma once 防止头文件被一个源文件重复包含 的相关文章

随机推荐