1.#define保护

使用#define防止头文件被多重包括。命名格式为:<PROJECT>_<PATH>_<FILE>_H_

比如,foo中的头文件foo/src/bar/baz.h

#ifndef FOO_BAR_BAZ_H_

#define FOO_BAR_BAZ_H_

...

#endif //FOO_BAR_BAZ_H_

2.头文件依赖

使用前置声明尽量降低.h文件里#include的数量。

头文件被更改时,须要又一次编译。那些包括了该头文件的代码也须要又一次编译,因此,我们应该实现尽可能少的在头文件里包括头文件。

前置声明能够明显的降低须要包括的头文件数量。假如你在一个头文件里须要用到类File,但不须要訪问File的声明,则头文件仅仅需前置声明class File。

在下面情况能够使用类Foo而无需訪问类的定义。

1)将数据成员类型声明为Foo *或者Foo &;

2)參数、返回值类型为Foo的函数仅仅是声明(不在头文件内定义实现);

3)静态数据成员的类型能够被声明为Foo(由于静态数据成员的定义在类定义之外)。

假设你的类是Foo的子类,或者含有类型为Foo的非静态数据成员,则必须为之包括头文件。

有时,使用指针成员替代对象成员的确更有意义。可是,这种做法会减少代码可读性及运行效率。假设只为了少包括头文件,还是不要替代比較好。

当然,.cc或者.cpp不管怎样都须要所使用类的定义部分,自然也就会包括若干头文件。

3.内联函数

仅仅有当函数仅仅有10行甚至更少时才会将其定义为内联函数。

当函数被声明为内联函数之后,编译器可能会将其内联展开,无需按通常的函数调用机制调用内联函数。

长处:当函数体比較小的时候,内联该函数能够令目标代码更加高效。比如存取函数,以及其它一些比較短的关键运行函数。

缺点:滥用内联将导致程序变慢,内联有可能使目标代码量或增或建,这取决与被内联的函数的大小。内联较短小的存取函数一般会降低代码量,但内联一个非常大的函数(假设编译器同意的话),将显著添加�代码量。

在如今处理器上,因为更好的利用指令缓存,小巧的代码往往运行更快。

一个比較得当的处理规则是,不要内联超过10行的函数。对于析构函数应谨慎对待,析构函数往往比其表面看起来要长,由于有一些隐式成员和基类析构函数(假设有的话)被调用。

虚函数和递归函数即使被声明为内联的,也不一定就是内联函数。通常,递归函数不应该被声明为内联的(递归调用堆栈的展开并不像循环那么简单,比方递归层数在编译时可能是未知的,大多数编译器都不支持内联递归函数)。析构函数内联的主要原因是其定义在类的定义中,为了方便抑或是对其行为给出文档。

4.-inl.h文件

复杂的内联函数的定义,应放在后缀名为-inl.h的头文件里。

在头文件里给出内联函数的定义,可令编译器将其在调用出内联展开。然后,实现代码应全然放到.cc文件里,我们不希望.h文件里出现太多实现代码,除非这样做在可读性和效率上有明显优势。

假设内联函数的定义比較短小、逻辑比較简单,事实上现代码能够放在.h文件里。比如,存取函数的实现理所当然都放在类定义中。处于实现和调用的方便,较复杂的内联函数也能够放到.h文件里,假设你认为这样会使头文件显得笨重,还能够将其分离到单独的-inl.h中。这样即把实现和类定义分离开来,当须要时包括实现所在的-inl.h就可以。

相同的,-inl.h也是须要#define保护的。

5.函数參数顺序

定义函数事,參数顺序为:输入參数在前,输出參数在后。

6.将包括次序标准化可增强可读性、避免隐藏依赖,次序例如以下:C库、C++库、其它库的.h、项目内的.h。

同样文件夹下头文件按字母序是不错的选择。

Google C++ style guide——头文件的更多相关文章

  1. Google C++ Style Guide在C++11普及后的变化

    转 http://www.cnblogs.com/chen3feng/p/5972967.html?from=timeline&isappinstalled=0&lwfrom=user ...

  2. Google C++ Style Guide的哲学

    Google C++ Style Guide并不是一个百科全书,也不是一个C++使用指南,但它描述适用于Google及其开源项目的编码指南,并不追求全面和绝对正确,也有许多人置疑它的一些规则.但作为一 ...

  3. [Guide]Google C++ Style Guide

    0.0 扉页 项目主页 Google Style Guide Google 开源项目风格指南 -中文版 0.1 译者前言 Google 经常会发布一些开源项目, 意味着会接受来自其他代码贡献者的代码. ...

  4. 一张图总结Google C++编程规范(Google C++ Style Guide)

    Google C++ Style Guide是一份不错的C++编码指南,我制作了一张比較全面的说明图,能够在短时间内高速掌握规范的重点内容.只是规范毕竟是人定的,记得活学活用.看图前别忘了阅读以下三条 ...

  5. electron教程(番外篇一): 开发环境及插件, VSCode调试, ESLint + Google JavaScript Style Guide代码规范

    我的electron教程系列 electron教程(一): electron的安装和项目的创建 electron教程(番外篇一): 开发环境及插件, VSCode调试, ESLint + Google ...

  6. Google Shell Style Guide

    转自:http://google.github.io/styleguide/shell.xml Shell Style Guide Revision 1.26 Paul Armstrong Too m ...

  7. Google JavaScript Style Guide

    转自:http://google.github.io/styleguide/javascriptguide.xml Google JavaScript Style Guide Revision 2.9 ...

  8. Google coding Style Guide : Google 编码风格/代码风格 手册/指南

    1 1 1 https://github.com/google/styleguide Google 编码风格/代码风格 手册/指南 Style guides for Google-originated ...

  9. [Guide]Google Python Style Guide

    扉页 项目主页 Google Style Guide Google 开源项目风格指南 - 中文版 背景 Python 是Google主要的脚本语言.这本风格指南主要包含的是针对python的编程准则. ...

随机推荐

  1. Linux 文件

    Linux系统中:.a文件是静态链接库文件.所谓静态链接是指把要调用的函数或者过程链接到可执行文件中,成为可执行文件的一部分.当多个程序都调用相同函数时,内存中就会存在这个函数的多个拷贝,这样就浪费了 ...

  2. start_kernel——local_irq_disable

    在启动初期须要关闭CPU的IRQ,原因: 因为尚未对中断代码.向量表,中断处理器进行初始化,所以必须关闭中断. 我的源码里面定义了 CONFIG_TRACE_IRQFLAGS_SUPPORT,所以调用 ...

  3. 监控代码运行时长 -- StopWatch用法例程

    在.net环境下,精确的测量出某段代码运行的时长,在网络通信.串口通信以及异步操作中很有意义.现在做了简单的总结.具体代码如下: (1).首先 using System.Diagnostics; (2 ...

  4. C#整理8——结构体

    结构体:相当于是我们自己定义的一种复杂的类型.int... double float bool char string DateTime 数组类型生活中大部份的对象都是复合型的对象. 如何定义结构体类 ...

  5. 那些 Cynthia 教我的事 之 PMSec (一)

    一.ViewState的使用 在项目中,我一直在用Common的方法读取一些信息,但是Cynthia习惯将它存入ViewState中. ViewState 它是由ASP.NET页面框架管理的一个隐藏的 ...

  6. Struts2 工作流程

    Struts2使用了WebWork的设计核心(XWork),在内部使用拦截器处理用户请求,从而允许用户业务逻辑控制器和ServletAPI分离.Struts2内部是一个MVC架构,Struts2 的核 ...

  7. vim中使用gdb。

    引用文章A:http://easwy.com/blog/archives/advanced-vim-skills-vim-gdb-vimgdb/ 引用介绍:使用vimgdb来完成gdb的嵌入. 需要的 ...

  8. 在Yii框架中使用PHPExcel

    PHPExcel是一个比较好用的php读取excel文件的类库,今天遇到了在yii中如何加载PHPExcel类文件的问题,因为Yii的autoload机制是安装类名去找文件,即文件名就是相应的类名,而 ...

  9. js 函数(function)

    <Javascript高级程序设计第三版> 3.7 函数 1. ECMAScript中的函数在定义时,不必指定是否返回值. 2. 位于return语句之后的任何code都永远不会执行.(之 ...

  10. plsql基本语法(

    1. 定义常量的语法格式    常量名 constant 类型标识符 [not null]:=值;    常量,包括后面的变量名都必须以字母开头,不能有空格,不能超过30个字符长度,同时不能和保留字同 ...