• # program once 用途 及与 ifndef使用异同


    在头文件中用这种写法就是为了该头文件被重复包含时不会出现符合重定义的错误。

     

    效果等同于
         #ifndef __xxx__
         #define __xxx__
         ...
        #endif // __xxx__


    详细如下:

    #pragma once和ifndef使用异同
    为了避免同一个文件被include多次
    1   #ifndef方式
    2   #pragma once方式
    在能够支持这两种方式的编译器上,二者并没有太大的区别,但是两者仍然还是有一些细微的区别。
           方式一:

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

    方式二:

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


        #ifndef的方式依赖于宏名字不能冲突,这不光可以保证同一个文件不会被包含多次,也能保证内容完全相同的两个文件不会被不小心同时包含。当然,缺点就是如果不同头文件的宏名不小心“撞车”,可能就会导致头文件明明存在,编译器却硬说找不到声明的状况
        #pragma once则由编译器提供保证:同一个文件不会被包含多次。注意这里所说的“同一个文件”是指物理上的一个文件,而不是指内容相同的两个文件。带来的好处 是,你不必再费劲想个宏名了,当然也就不会出现宏名碰撞引发的奇怪问题。对应的缺点就是如果某个头文件有多份拷贝,本方法不能保证他们不被重复包含。当 然,相比宏名碰撞引发的“找不到声明”的问题,重复包含更容易被发现并修正。
       方式一由语言支持所以移植性好,方式二 可以避免名字冲突
      
       实际上,我们平常包含的#include "stdafx.h",其中的代码就是

    #pragma once

    #include "targetver.h"

    #include <stdio.h>
    #include <tchar.h>

    但是不用担心其中的stdio.h等被重复调用,因为,stdio.h中的内容是

    #if     _MSC_VER > 1000
          #pragma once
          #endif

    #ifndef _INC_STDIO
          #define _INC_STDIO

    。。。

  • 相关阅读:
    堆排序
    理解KMP算法
    C++性能提升
    论文阅读 | Pre-trained Models for Natural Language Processing: A Survey
    模型融合
    论文阅读 | COMPRESSING BERT: STUDYING THE EFFECTS OF WEIGHT PRUNING ON TRANSFER LEARNING
    论文阅读 | Compressing Large-Scale Transformer-Based Models: A Case Study on BERT
    沉淀再出发:关于netty的一些理解和使用
    沉淀再出发:mongodb的使用
    沉淀再出发:ElasticSearch的中文分词器ik
  • 原文地址:https://www.cnblogs.com/zhaoxinshanwei/p/4117211.html
Copyright © 2020-2023  润新知