zoukankan      html  css  js  c++  java
  • 头文件为什么要加#ifndef #define #endif

    #ifndef 在头文件中的作用

    在一个大的软件工程里面,可能会有多个文件同时包含一个头文件,当这些文件编译链接成一个可执行文件时

    ,就会出现大量“重定义”的错误。在头文件中实用#ifndef #define #endif能避免头文件的重定义。

    方法:例如要编写头文件test.h

    在头文件开头写上两行:

    #ifndef _TEST_H

    #define _TEST_H//一般是文件名的大写

    头文件结尾写上一行:

    #endif

    这样一个工程文件里同时包含两个test.h时,就不会出现重定义的错误了。

    分析:当第一次包含test.h时,由于没有定义_TEST_H,条件为真,这样就会包含(执行)#ifndef _TEST_H和

    #endif之间的代码,当第二次包含test.h时前面一次已经定义了_TEST_H,条件为假,#ifndef _TEST_H和

    #endif之间的代码也就不会再次被包含,这样就避免了重定义了。

    #ifndef __74HC595_H__
    #define __74HC595_H__



    #endif

    #ifndef _optimizedvector_h // if not define _optimizedvector_h
    #define _optimizedvector_h // then define _optimizedvector_h

    通俗点就是如果没定义_optimizedvector_h,那就定义_optimizedvector_h,防止重复编译

    头文件中的#ifndef,这是一个很关键的东西。比如你有两个C文件,这两个C文件都include了同一个头文件。而编

    译时,这两个C文件要一同编译成一个可运行文件,于是问题来了,大量的声明冲突。

    还是把头文件的内容都放在#ifndef和#endif中吧。不管你的头文件会不会被多个文件引用,你都要加上这个。一般

    格式是这样的:


    #ifndef <标识>
    #define <标识>
    ......
    #endif


    <标识>在理论上来说可以是自由命名的,但每个头文件的这个“标识”都应该是唯一的。标识的命名规则一般是头

    文件名全大写,前后加下划线,并把文件名中的“.”也变成下划线,

    如:stdio.h
    #ifndef _STDIO_H_
    #define _STDIO_H_
    ......
    #endif

  • 相关阅读:
    今天发现之前瑞乐做的登录和注册居然都是用的get请求,瞬间出了一身冷汗.
    用grunt进行前端工程化之路
    移动端开发库zepto 之我思
    构造高度自适应的textarea
    maxlength属性在textarea里奇怪的表现
    在windows下使用linux的开发环境
    移动web开发的一些坑
    [译]开始学习webpack
    完美解决移动Web小于12px文字居中的问题
    再谈移动端Web屏幕适配
  • 原文地址:https://www.cnblogs.com/huanzxj/p/5396183.html
Copyright © 2011-2022 走看看