#pragma once与#ifndef #define ...#endif的区别

  #pragma once用来防止某个头文件被多次include,特点是与编译系统有关,移植性差一点,不过现在基本所有的编译器都有这个定义。

  #ifndef,#define,#endif用来防止某个宏被多次定义。特点是与C++语言相关,通过宏定义避免文件被多次编译,如果要跨平台最好使用此方式。(依赖于宏名称不能冲突),一般宏使用  __头文件_H__


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

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


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

放在一起使用,看起来似乎兼有两者的优点。不过只要使用了#ifndef就会有宏名冲突的危险,所以混用两种方法似乎不能带来更多的好处,倒是会让一些不熟悉的人感到困惑。可以调整下顺序兼顾两者优点,将#pragma once 放在中间:

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

猜你喜欢

转载自blog.csdn.net/vict_wang/article/details/81209288
今日推荐