您的位置:首页 > 编程语言 > C语言/C++

Google C++编程规范 – 第十九条 -《前置声明》

2014-12-09 07:06 363 查看
转自:http://roclinux.cn/?p=3285

本原创文章属于《Linux大棚》博客。

博客地址为http://roclinux.cn

文章作者为roc wu

==

【规范】

对于普通的类,建议使用前置声明,而不是#include。

【什么是前置声明】

在英文中,前置声明称为“forward declaration”,是指“对类、函数或模板进行声明,且不含相关的具体定义”。我们可以使用前置声明来代替那些用于声明的#include语句。

【支持者的声音】

过多的#include会导致编译器打开很多的文件,并处理很多的输入内容。另外,当头文件内容修改时,也会导致更多次的重新编译。

如果我们使用前置声明,可以避免上述问题。

【反对者的声音】

在使用模板、typedef、默认参数等语法时,我们就比较难确定前置声明的正确形式了 ;

对于一段代码片段,我们很难决定是使用前置声明还是使用#include,尤其是在有隐式转换操作时。在一些极端情况下,用前置声明代替#include会完全改变代码的原意。

如果要前置声明过多的内容,会显得很冗余拖沓,不如#include简单。

对函数和模板的前置声明,会阻碍原作者对函数或模板的改进,比如调整一个参数的类型,给模板的参数增加一个默认值等。

对名字空间std::中标记的前置声明,经常会产生“未定义”的报错。

如果特意调整代码以便使用前置声明,往往会使得代码运行变慢,代码逻辑变复杂,比如用指针成员代替对象成员等。

前置声明对代码效率的收益,目前也没有得到有力的证明。

【结论】

如果要使用头文件中的某个函数,请使用#include方法引用头文件

如果要使用头文件中的某个类模板,请使用#include方法引用头文件

如果要使用某个普通的类,建议使用前置声明。

不必只是为了避免使用#include,而用指针成员替代对象成员。

谢谢!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: