前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Windows客户端C/C++编程规范“建议”——文件

Windows客户端C/C++编程规范“建议”——文件

作者头像
方亮
发布2019-01-16 14:31:07
8230
发布2019-01-16 14:31:07
举报
文章被收录于专栏:方亮方亮

7 文件

7.1 正确使用#include 

等级:【推荐】

说明:#include <>和#include “”导致编译器在搜索文件时,搜索的路径顺序不同。所以需要正确使用#include,以避免包含错了头文件。

语法形式

操作

带引号的形式

预处理器按以下顺序搜索包含文件: 在包含 #include 语句的文件所在的同一目录中。 在当前打开的包含文件的目录中,采用与打开它们的顺序相反的顺序。 搜索从父包含文件的目录中开始进行,然后继续向上到任何祖父包含文件的目录。 跟随每个 /I 编译器选项指定的路径。 跟随 INCLUDE 环境变量指定的路径。

尖括号形式

预处理器按以下顺序搜索包含文件: 跟随每个 /I 编译器选项指定的路径。 通过命令行进行编译时,跟随 INCLUDE 环境变量指定的路径。

  1. 在包含 #include 语句的文件所在的同一目录中。
  2. 在当前打开的包含文件的目录中,采用与打开它们的顺序相反的顺序。 搜索从父包含文件的目录中开始进行,然后继续向上到任何祖父包含文件的目录。
  3. 跟随每个 /I 编译器选项指定的路径。
  4. 跟随 INCLUDE 环境变量指定的路径。

尖括号形式 预处理器按以下顺序搜索包含文件:

  1. 跟随每个 /I 编译器选项指定的路径。
  2. 通过命令行进行编译时,跟随 INCLUDE 环境变量指定的路径。

7.2 重复引用头文件需控制

等级:【必须】 说明:不可避免的头文件引用存在交叉的场景,所以在定义头文件时,使用域控制等方法控制重复引用问题。         例子:

代码语言:javascript
复制
#pragma once
// 头文件实际内容

        或

代码语言:javascript
复制
#ifndef PATH_XXX_HEADER_H
#define PATH_XXX_HEADER_H
// 头文件实际内容
#endif

        对于使用#define方式确保头文件不会被重复包含,需要考虑定义的宏名称的唯一性。推荐使用“文件路径”+“_”+“文件名”的方式。比如trunk/core/src/filecheck.h的宏为TRUNK_CORE_SRC_FILECHECK_H。

7.3 头文件中不要定义全局变量

等级:【要求】 说明:减少代码膨胀。

7.4 头文件引用顺序

等级:【推荐】 说明:按如下顺序布局头文件:

  1. C(标准) 库
  2. C++(标准)库
  3. Boost库
  4. 其他库
  5. 自己Project头文件

7.5 减少头文件依赖

等级:【推荐】

说明:通过前置声明的方法替代include文件头的方式,可以减少头文件依赖。这对编译速度有提升。

(转载请指明出于breaksoftware的csdn博客)

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2014年08月01日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 7 文件
    • 7.1 正确使用#include 
      • 7.2 重复引用头文件需控制
        • 7.3 头文件中不要定义全局变量
          • 7.4 头文件引用顺序
            • 7.5 减少头文件依赖
            领券
            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档