31 : Minimize compilation dependencies between files


1 这关乎C++的类(或说都是类惹的祸)

1.1 C++类定义式的问题

C++类定义式不只叙述了class接口,还包括十足的实现细目。将导致编译依存关系(compilation dependency),更严重的将导致 连串编译依存关系(cascading compilation dependencies),会对许多项目造成难以形容的灾难。

通常是指类的内部成员,解决方法有两种

1.1.1 pimpl idiom设计(pointer to the implementation)

pimpl idiom pattern:
// handle class
class Person {
...
private:
std::tr1::shared_ptr<PersonImpl> pImpl; // 指向实物
};

1.1.2 虚基类(常用的接口设计)

// interface class

这是一个“将对象实现细目隐藏于一个指针背后”的游戏。

1.2 错误的前置声明

考虑以下代码:
namespace std {
class string; // 并不正确
}

原因:string是一个typedef,定义为basic_string< char >

通常情况下不需要对标准库进行前置声明,但要注意避免使用标准库程序中的“引发不受欢迎之#include”。


1 如果使用object references或object pointers可以完成任务,就不要使用objects。

你可以只靠一个类型声明式就定义出指向该类型的references和pointers;但如果定义某类型的objects ,就需要用到该类型的定义式。

2 如果能够,尽量以class声明式替换class定义式

class Date;
Date foo( Date d );
// 作为返回值、函数参数、没有任何问题。
// 当然pass-by-value是个糟糕的主意。

疑问:为什么?是因为函数签名或者说函数声明的原因吗?

3 为声明式和定义式提供不同的头文件

// 同上
#include "datefwd.h"
// 参考标准库<iosfwd>(见条款54)
Date foo( Date d );

它分外彰显本条款适用于模版与非模版。有些环境允许模版的实现与声明分离,那就可以提供一份只包含声明的头文件。同时有一个叫做export的关键字可实现模版的这一性质,有必要关心这一关键字的发展。

2 总结

2.1 犬儒学派的质疑

“将对象实现细目隐藏于一个指针背后”的游戏,很遗憾必须牺牲运行时的速度与空间。

2.2 抉择

那究竟何时应当使用“将对象实现细目隐藏于一个指针背后”这一手段与否?

程序发展过程中这两种方法以求实现代码有所变化时对其客户带来最小冲击。而当他们导致速度和/或大小差异过于重大以至于classes之间的耦合相形之下不成为关键时,就以具象类替换这两种方法。


请记住

1 一般构想是handle classes和interface class这两个手段。

2 程序库头文件应该以“完全且仅有声明式”(full and declaration-only forms)


专业词汇


compilation dependency
cascading compilation dependencies precompiled headers
parasing pipl idiom handle classes
interface classes
concrete classes full declaration-only forms

Effective C++ 笔记:条款 31 将编译关系降至最低的更多相关文章

  1. Effective C++ -----条款31:将文件间的编译依存关系降至最低

    支持“编译依存性最小化”的一般构想是:相依于声明式,不要相依于定义式.基于此构想的两个手段是Handle classes 和 Interface classes. 程序库头文件应该以“完全且仅有声明式 ...

  2. 读书笔记_Effective_C++_条款三十一:将文件间的编译依存关系降至最低(第三部分)

    下面来谈谈书中的第二部分,用Interface Classes来降低编译的依赖.从上面也可以看出,避免重编的诀窍就是保持头文件(接口)不变化,而保持接口不变化的诀窍就是不在里面声明编译器需要知道大小的 ...

  3. 条款31:将文件间的编译依存关系降至最低(Minimize compilation dependencies between files)

    NOTE1: 1.支持“编译依存性最小化”的一般构想是:相依于声明式,不要相依于定义式.基于此构想的两个手段是Handle classes 和 Interface classes. 2.程序库头文件应 ...

  4. [Effective C++ --031]将文件间的编译依存关系降至最低

    引言:编译时间成本 在项目中我们都会碰到修改既存类的情况:某个class实现文件做了些轻微改变,修改的不是接口,而是实现,而且只改private成分. 重新build这个程序,并预计只花数秒就好,当按 ...

  5. [Effective JavaScript 笔记]第31条:使用Object.getPrototypeOf函数而不要使用__proto__属性

    ES5引入Object.getPrototypeOf函数作为获取对象原型的标准API,但由于之前的很多js引擎使用了一个特殊的__proto__属性来达到相同的目的.但有些浏览器并不支持这个__pro ...

  6. [EffectiveC++]item31:将文件间的编译依存关系降至最低

    P143:“声明的依赖性"替换“定义的依存性”

  7. Effective C++笔记:实现

    条款26:尽可能延后变量定义式的出现时间 博客地址:http://www.cnblogs.com/ronny/ 转载请注明出处! 有些对象,你可能过早的定义它,而在代码执行的过程中发生了导常,造成了开 ...

  8. Effective C++笔记 55条编程法则

    1.  视C++为一个语言联邦 C++高效编程守则视状况而变化,取决于你使用C++的哪一部分. 2.  尽量以const,enum.inline替代#define 1) 对于单纯常量,最好以const ...

  9. Effective C++笔记05:实现

    条款26:尽可能延后变量定义式的出现时间 博客地址:http://blog.csdn.net/cv_ronny 转载请注明出处! 有些对象,你可能过早的定义它,而在代码运行的过程中发生了导常,造成了開 ...

随机推荐

  1. Excel 二维数组(数据块)旋转/翻转技巧

    Excel 二维数组(数据块)旋转/翻转技巧 原创 2017-12-30 久石六 久石六 工作中遇到个问题,需要将Excel中的数据块或者说二维数组向右旋转90度,才能再加工处理.当然,不是旋转文本方 ...

  2. C++Primer第五版——习题答案详解(八)

    习题答案目录:https://www.cnblogs.com/Mered1th/p/10485695.html 第9章 顺序容器 练习9.1 a.list,需要按字典序插入,可能插入位置在中间 b.d ...

  3. c# 数据结构 ArrayList

    数据结构 描述数据之间的关系 行为:添加数据,删除数据,插入数据,查找数据,修改数据 追加数据:向这个结构的末尾添加一个数据 删除数据:在这个结构中删除你指定的数据 插入数据:向这个结构中某一个位置插 ...

  4. CSS的background

    .block{ width: 200px; height: 200px; padding: 25px; background-image:linear-gradient(#58a,#58a) ,lin ...

  5. MRO,C3算法

    1了解python2和python3类的区别 python2在2.4之前使用的是经典类, 2.4之后, 使用的是新式类 class Foo: pass class Foo(object): pass ...

  6. 学习笔记 requests + BeautifulSoup

    第一步:requests get请求 # -*- coding:utf-8 -*- # 日期:2018/5/15 17:46 # Author:小鼠标 import requests url = &q ...

  7. C# 操作符 << 与 >>

    1.<< 左移操作符: 左移操作符,将第一个操作数向左移动第二个操作数指定的位数,空出的位置补0.左移相当于乘. 左移一位相当于乘2;左移两位相当于乘4;左移三位相当于乘8. 如:x< ...

  8. android 开发 View _13 绘制图片与BitmapShader位图的图像渲染器

    BitmapShader位图的图像渲染器 TileMode 模式 Shader.TileMode.CLAMP 边缘拉伸. Shader.TileMode.MIRROR 在水平方向和垂直方向交替景象, ...

  9. python数据分析库pandas

    在我看来,对于Numpy以及Matplotlib,Pandas可以帮助创建一个非常牢固的用于数据挖掘与分析的基础.而Scipy(会在接下来的帖子中提及)当然是另一个主要的也十分出色的科学计算库,但是我 ...

  10. 【FZSZ2017暑假提高组Day1】确定小组

    [问题描述] 有n个人坐成一排,这n个人都在某一个小组中,同一个小组的所有人所坐的位置一定是连续的. 有一个记者在现场进行采访,他每次采访都会询问一个人其所在的小组有多少人,被询问的每个人都给出了正确 ...