pragma once 之前一直用的很好,今天和同事的配合中发现自己没有真正理解pragma once。
原因:同事喜欢把公共的头文件通过生成后事件复制到一个公共的include文件夹中。
摘抄:
#ifndef方式:
#ifndef __SOMEFILE_H__
#define __SOMEFILE_H__ 1 ... ... // 一些声明语句
#endif
#ifndef的方式依赖于 宏名字不能冲突 ,这不光可以保证同一个文件不会被包含多次,也能保证内容完全相同的两个文件不会被不小心同时包含。当然,缺点就是如果不同头文件的宏名不小心“撞车”,可能就会导致头文件明明存在,编译器却硬说找不到声明的状况
#pragma方式
#pragma once ... ... // 一些声明语句
#pragma once 是个预处理指令,在头文件的最开始加入这条指令表示:这个头文件只被编译一次 #pragma once则由编译器提供保证:同一个文件不会被包含多次。注意这里所说的“同一个文件”是 指物理上的一个文件 ,而不是指内容相同的两个文件。带来的好处 是,你不必再费劲想个宏名了,当然也就不会出现宏名碰撞引发的奇怪问题。 对应的缺点就是如果某个头文件有多份拷贝,本方法不能保证他们不被重复包含。 当 然,相比宏名碰撞引发的“找不到声明”的问题,重复包含更容易被发现并修正。
总结: 1. #ifndef 由语言支持所以移植性好,#pragma 可以避免名字冲突
原因:同事喜欢把公共的头文件通过生成后事件复制到一个公共的include文件夹中。
摘抄:
#ifndef方式:
#ifndef __SOMEFILE_H__
#define __SOMEFILE_H__ 1 ... ... // 一些声明语句
#endif
#ifndef的方式依赖于 宏名字不能冲突 ,这不光可以保证同一个文件不会被包含多次,也能保证内容完全相同的两个文件不会被不小心同时包含。当然,缺点就是如果不同头文件的宏名不小心“撞车”,可能就会导致头文件明明存在,编译器却硬说找不到声明的状况
#pragma方式
#pragma once ... ... // 一些声明语句
#pragma once 是个预处理指令,在头文件的最开始加入这条指令表示:这个头文件只被编译一次 #pragma once则由编译器提供保证:同一个文件不会被包含多次。注意这里所说的“同一个文件”是 指物理上的一个文件 ,而不是指内容相同的两个文件。带来的好处 是,你不必再费劲想个宏名了,当然也就不会出现宏名碰撞引发的奇怪问题。 对应的缺点就是如果某个头文件有多份拷贝,本方法不能保证他们不被重复包含。 当 然,相比宏名碰撞引发的“找不到声明”的问题,重复包含更容易被发现并修正。
总结: 1. #ifndef 由语言支持所以移植性好,#pragma 可以避免名字冲突