c++ 防止头文件重复include问题

2024年12月04日 23:16
有5个网友回答
网友(1):

都是为了避免同一个文件被include多次:
1 #ifndef方式
2 #pragma once方式

在能够支持这两种方式的编译器上,二者并没有太大的区别,但是两者仍然还是有一些细微的区别。
方式一:

#ifndef __SOMEFILE_H__
#define __SOMEFILE_H__
... ... // 一些声明语句
#endif

方式二:

#pragma once
... ... // 一些声明语句

#ifndef的方式依赖于宏名字不能冲突,这不光可以保证同一个文件不会被包含多次,也能保证内容完全相同的两个文件不会被不小心同时包含。当然,缺点就是如果不同头文件的宏名不小心“撞车”,可能就会导致头文件明明存在,编译器却硬说找不到声明的状况

#pragma once则由编译器提供保证:同一个文件不会被包含多次。注意这里所说的“同一个文件”是指物理上的一个文件,而不是指内容相同的两个文件。带来的好处是,你不必再费劲想个宏名了,当然也就不会出现宏名碰撞引发的奇怪问题。对应的缺点就是如果某个头文件有多份拷贝,本方法不能保证他们不被重复包含。当然,相比宏名碰撞引发的“找不到声明”的问题,重复包含更容易被发现并修正。

方式一由语言支持所以移植性好,方式二 可以避免名字冲突。

一般可以这样处理:

#infndef XX
#define XX
#if _MSC_VER > 1000
#pragma once
#endif
.
.
#endif

注意:_MSC_VER 是出于版本兼容性考虑,定义
Defines the compiler version. Defined as 1200 for Microsoft Visual C++ 6.0. Always defined.

网友(2):

#pragma once
这个指令是后来才加的,以前的版本没有。

新的 vc 2008 生成的代码, 只在开头地方加 #pragma once 一句了,其他的都省略了。

网友(3):

常使用的#ifndef和#endif语句。
比如说在头文件中要#define IRremote_h,则可以使用
#ifndef IRremote_h
#define IRremote_h
//如果重复,这里的代码将被跳过

#endif

网友(4):

因为#pragma once是后来引入的功能。必须要在MSC版本数满足要求时才能使用。

网友(5):

你如果是用的编译器自带的文件,它们会自动判别的。
如果你自己定义的头文件
简单的在头文件的这样就可以了啊

myh1.h
#if! defined MYH1
#define MYH1
#endif

这样你怎么include都保证不会重复。