博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
#pragma once与#ifndef #define ...#endif的区别
阅读量:7087 次
发布时间:2019-06-28

本文共 1136 字,大约阅读时间需要 3 分钟。

hot3.png

1. 

     #pragma once用来防止某个头文件被多次include;

     #ifndef,#define,#endif用来防止某个宏被多次定义。

 

2. 

      #pragma once是编译相关,就是说这个编译系统上能用,但在其他编译系统不一定可以,也就是说移植性差,不过现在基本上已经是每个编译器都有这个定义了;

  #ifndef,#define,#endif这个是C++语言相关,这是C++语言中的宏定义,通过宏定义避免文件多次编译。所以在所有支持C++语言的编译器上都是有效的,如果写的程序要跨平台,最好使用这种方式。

 
3.使用方式不同: 

   方式一:

复制代码
#ifndef __SOMEFILE_H__  #define __SOMEFILE_H__  ... ... // 一些声明语句  #endif
复制代码

 

 

  方式二:

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

 

    
     方式一由语言支持所以移植性好,方式二 可以避免名字冲突(详细请看第4点) 
 

4.  

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

 

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

 

  #pragma once方式产生于#ifndef之后,因此很多人可能甚至没有听说过。目前看来#ifndef更受到推崇。因为#ifndef受语言天生的支持,不受编译器的任何限制;而#pragma once方式却不受一些较老版本的编译器支持,换言之,它的兼容性不够好。也许,再过几年等旧的编译器死绝了,这就不是什么问题了。

 
PS:
       我还看到一种用法是把两者放在一起的:
 
#pragma once#ifndef __SOMEFILE_H__#define __SOMEFILE_H__... ... // 一些声明语句#endif

 

  看起来似乎是想兼有两者的优点。不过只要使用了#ifndef就会有宏名冲突的危险,所以混用两种方法似乎不能带来更多的好处,倒是会让一些不熟悉的人感到困惑。

转载于:https://my.oschina.net/verynix/blog/365886

你可能感兴趣的文章
Oracle数据库中几种常见的SCN
查看>>
nebula3 源码分析
查看>>
PKU 3669 Meteor Shower(BFS)
查看>>
mac 下批量转换文件类型
查看>>
何为DOM对象
查看>>
linux的yum仓库配置
查看>>
XSUPERSMS COME ON
查看>>
使用ABP框架踩过的坑系列2
查看>>
工作经验之报表使用
查看>>
【381】python 获取列表中重复元素的索引值
查看>>
【C006】ArcGIS VBA - IMap & ILayer
查看>>
Android使用Jenkins自动化构建测试打包apk
查看>>
谈一谈python的垃圾回收机制
查看>>
vue---监听浏览器窗口的宽度
查看>>
vue--指令
查看>>
thinkphp---自动验证的问题
查看>>
Oracle 分区表
查看>>
android progressbar 水平进度条
查看>>
解决yum升级的问题“There was a problem importing one of the Python modules”
查看>>
kettle_删除“共享输出表”引发的错误
查看>>