C++程序包含头文件的规范注意要点

一、规范用双引号和尖括号包含头文件

双引号

#include "header.h"
//表明当前文件和"header.h"处于同一工程且同一目录

尖括号

#include <header.h>
//表明header.h和当前文件不属于同一工程,是外部引用

有时候找不到外部的头文件:就需要用cmake的include_directories把目标头文件包含进来

在这里插入图片描述

二、防止头文件重复包含的方法

1)条件编译

  • 格式类似
#ifndef _ASYNC_QUEUE_
#define _ASYNC_QUEUE_

巴拉巴拉。。。。。

#endif //_ASYNC_QUEUE_
  • 思路
    在被重复包含的头文件内部加上条件编译的宏定义
  • 作用
    #ifndef方式是C/C++语言的标准支持,也是比较常用的方式,#ifndef的方式依赖于自定义的宏名(例中的_CODE_BLOCK)不能冲突,它不光可以保证同一份文件不会被包含两次,也能够保证不同文件完全相同的内容不会被包含两次。但,同样的,如果自定义的宏名不小心“重名”了,两份不同的文件使用同一个宏名进行#ifndef,那么会导致编译器找不到声明的情况(被编译器判定为重定义而屏蔽了)。

2)#pragma once

  • 使用
    在想要保护的文件开头写入
#pragma once
  • 作用
    #pragma once一般由编译器提供保证:同一个文件不会被包含多次。这里所说的”同一个文件”是指物理上的一个文件,而不是指内容相同的两个文件。无法对一个头文件中的一段代码作#pragma once声明,而只能针对文件。此方式不会出现宏名碰撞引发的奇怪问题,大型项目的编译速度也因此提供了一些。

  • 缺点
    如果某个头文件有多份拷贝,此方法不能保证它们不被重复包含。在C/C++中,#pragma once是一个非标准但是被广泛支持的方式。

  • 与条件编译的区别
    #pragma once方式产生于#ifndef之后。#ifndef方式受C/C++语言标准的支持,不受编译器的任何限制;而#pragma once方式有些编译器不支持(较老编译器不支持,如GCC 3.4版本之前不支持#pragmaonce),兼容性不够好。#ifndef可以针对一个文件中的部分代码,而#pragma once只能针对整个文件。相对而言,#ifndef更加灵活,兼容性好,#pragma once操作简单,效率高。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
 C++领域20年集大成之作   两位世界专家联袂巨献   适合所有层次C++程序员   良好的编程规范可以改善代码质量,缩短上市时间,提升团队效率,简化维护工作。在本书中,两位全世界受尊敬的C++专家将全球C++社区的集体智慧和经验凝结成一整套编程规范。这些规范可以作为每一个开发团队制定实际开发规范的基础,更是每一位C++程序员应该遵循的行事准则。   本书涵盖了C++程序设计的每一个方面,包括设计和编码风格、函数、操作符、类的设计、继承、构造与析构、赋值、名字空间、模块、模板、泛型、异常、STL容器和算法等。书中对每一条规范都给出了言简意赅的概述,并辅以实例说明;另外还给出了从类型定义到错误处理等方面的大量C++实践,包括许多总结和标准化的技术。即使使用C++多年的程序员也会从中受益匪浅。   通过阅读本书,可以找到以下问题的答案。   哪些东西值得标准化?哪些东西不值得标准化?   使代码可扩展的方法是什么?   合理的错误处理策略有哪些要素?   如何(和为什么要)避免不必要的初始化、循环依赖和定义依赖?   何时应该(以及如何)同时使用静态和动态的多态性;   如何实践“安全的”改写?   何时该提供不会失败的交换?   为什么阻止异常跨越模块边界传播?如何阻止?   为什么不应该在头文件中写名字空间声明或指令?   为什么应该使用STL vector和string代替数组?   如何选择正确的STL搜索或排序算法?   为了保证代码的类型安全,应该遵从哪些规则?
华为C++语言编程规范包括以下几个方面的内容: 1. 程序块的分界符应独占一行并位于同一列,同时与引用它们的语句左对齐。在函数体的开始、类的定义、结构的定义、枚举的定义以及if、for、do、while、switch、case语句中的程序都要采用如上的缩进方式。\[1\] 2. 头文件包含顺序应按照以下顺序:当前.cpp文件直接关联的头文件、C库文件、C++库文件、其他项目的头文件、本项目中的其他头文件头文件应向稳定的方向包含。\[2\] 3. 对于转换运算符和单参数构造函数,建议使用explicit关键字来明确指定其作用。这样可以避免隐式类型转换带来的潜在问题。\[3\] 以上是华为C++语言编程规范的一些主要内容。遵循这些规范可以提高代码的可读性和可维护性。 #### 引用[.reference_title] - *1* [华为C/C++编码规范](https://blog.csdn.net/weixin_67336587/article/details/130940891)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [C++编程规范(参考Google、华为)](https://blog.csdn.net/qq_39632811/article/details/124098935)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值