大型项目开发: 隔离 (《大规模C++程序设计》书摘)

书中第六章 隔离。 主要在撰述什么须要定义在头文件?什么应当移到编译单元中?

核心仍然是先区分接口定义与实现细节。实现细节的改变会导致客户代码的又一次编译,从逻辑上也表示与客户代码间可能存在着强耦合。

实现细节与隔离

主要考察下面实现细节。它们会在接口中引入实现细节。也是须要考虑进行隔离的内容:

  1. 继承
  2. 分层

    简单的说就是类的成员中有还有一个类的实例时,如Foo mFoo. 这个类就会依赖于Foo的定义。而转为持有地址时,即将关系从HasA改为HoldA时,就不存在这个问题。也就是定义为Foo* mFoo;或Foo& mFoo; 这也是Google C++ Coding Style以前就降低头文件依赖建议过的方式,后来则去掉了这项建议,改为:”不要为了使用前置声明,将成员变量改为指针类型”, 由于它反而添加了逻辑上的复杂度,比方额外的判空处理。

  3. 内联函数
  4. 私有成员
  5. 保护成员
  6. 编译器生成的默认实现函数,如拷贝。
  7. 包括指令,即头文件的包括。
  8. 默认參数
  9. 枚举

    在一些大型项目中。一些存有基本枚举类型的头文件。最后变成没人敢改,而更愿意新增头文件。事实上还不如放到详细的域或类中定义。

后面作者对各个细节推荐一些手法。相对照较简单。后面则介绍了几个经常使用手法:

  1. 协议类(接口类)
  2. Opaque Pointer和PIMPL
  3. Wrapper (封装器), 即引入中间层。

过程接口

考虑到上层代码对底层的操作需求。作者提出了过程接口(The Procedural Interface),能够结合常见的API来理解,它是一组函数的集合。出如今组件的顶部,并将功能的一个子集暴露给用户。

作者概括了编程接口的要求:

  1. 接口必须提供必要的功能来操纵底层系统。

  2. 接口一定不能暴露专属的实现细节。
  3. 底层组织的变化必须与client程序相隔离。
  4. 与该接口相关的开销一定不能过大。

在实现方式上,以面向对象的Wrapper来实现这种需求最佳的。而过程接口将针对无法简单使用独立的封装类来实现的系统。

事实上一个大型系统也是能够拆分出不同的领域。分别以Wrapper的形式来实现的。能够对照WebView的接口。以及Blink中的web层次。

书中主要是探讨了针对所持有对象的操作。

上面也提到的Opaque Pointer。还特别说明了Handle(句柄)模式来管理动态分配的对象。

一个过程接口既不是面向对象的也不是特别美观。但它确有一个非常大的长处:过程接口总是能够用于将大系统的组织与client程序相隔离–即使在设计的早期阶段并没有考虑这种接口。

隔离或不隔离

隔离会引入一些开销。选择是否进行隔离的常见原因包括:

  1. 暴露 (被使用的范围。或者扇入)
  2. 訪问数据的性能
  3. 创建对象的性能
  4. 开发成本 (在没有明白理由的情况强行隔离。会引入额外的开发工作)
  5. 组件的数量 (可能会新增组件,添加维护成本)
  6. 组件的复杂性 (引入新的复杂度。导致难以理解和维护)

作者提供两套经验值供决策时參考(中文编译的图表不太严谨,第5章有图标错。这里明明是两个表,却合成了一个表。)。

訪问的相对开销

  1. 内联函数传递值 : 1
  2. 内联函数传递指针 : 2
  3. 非内联函数,非虚函数 : 10
  4. 虚函数机制 : 20

创建相对于单独分配的成本

  1. 自己主动 (栈上) : 1.5
  2. 动态 (堆上) : 100+

作者最后讨论隔离决策时,建议是否进行隔离取于被使用的范围,性能要求的高低,以及成员函数的大小(是否轻量级)。性能要求高不要隔离。轻量级的实现也不须要隔离。

事实上就是隔离本身会引入开销。假设为了隔离引入的开销过式,或者引入更不稳定的复杂度。就不要急于隔离。而对于大型、广泛使用的对象则要尽早隔离。

时间: 2024-08-10 16:24:47

大型项目开发: 隔离 (《大规模C++程序设计》书摘)的相关文章

CakeDC(cakephp company)Git workflow--适合于较大团队大型项目开发

CakeDC Git workflow是一个项目开发和版本发布的工作流,在这个工作流程中开发和版本发布周期是基于几个关键阶段(key phases): Development: 所有活跃的开发活动都由里程碑驱动,在这个阶段的产出是很不稳定的代码基线 QA: Quality assurance testing作为一开发周期的一部分,主要协助确保需求的满足性和质量的可接受性 Review 客户或者评审员面对的是一个稳定的代码基线,该基线已经经过了QA流程,质量上已经被QA人员认可 Release 发

大型项目开发: 头文件顺序

经验告诉我们,某些编码实践虽然在C++中完全合法,但是绝对不能应用于大型项目环境中. 大型项目环境下必须有适当的约束,否则很容易变得难以控制并很难维护(摘自<<大规模C++程序设计>>).下面以Chromium中运用的两个Coding Style中定义的头文件顺序为例. 头文件顺序的差异 WebKit/Blink遵循业界标准的定义,其实也是Lakos在<<大规模C++程序设计>>中建议的顺序 : 编译单元对应的头文件 (Related header file

iOS大型项目开发漫谈

标题有些吓人请不要害怕,不过这确实不是扫盲贴,需要一定的iOS开发基础.在我多年的码农生涯中绝大部分时间都是做的小项目,大一些的可能也就是百万行代码的样子,跟Windows系统几千万行源码比简直就是小巫见大巫.不过,一个iOS项目的源码有数百万行算蛮大了.我想说的是,人总是会成长,会担当更大的责任接受更大的挑战,终有一天组织会有重要任务交给你.不过软件开发不是一朝一夕,也不会有多么的轰轰烈烈,更多的是平淡中无数的细节处理.做大型项目未必就需要多么高深的技术,也许就是细节的科学处理与规范的管理.

iOS 大型项目开发漫谈

标题有些吓人请不要惧怕,不过这的确不是扫盲贴,需要必定的iOS开发根底.在我多年的码农生计中绝大部分时刻都是做的小项目,大一些的可能也即是百万行代码的姿态,跟Windows体系几千万行源码比几乎即是小巫见大巫.不过,一个iOS项目的源码稀有百万行算蛮大了.我想说的是,人老是会生长,会担任更大的职责接受更大的应战,终有一天安排会有主要任务交给你.不过软件开发不是一朝一夕,也不会有多么的轰轰烈烈,更多的是平平中很多的细节处理.做大型项目未必就需要多么深邃的技能,或许即是细节的科学处理与规范的管理.

Java大型项目开发(1):配置Dubbox

CentOS的配置: 1.给CentOS安装Zookeeper: 网络配置成仅主机 上传tar.gz:比如用FTP tar -xvzf ... cd zookeeper mkdir data cd conf mv zoo_sample.cfg zoo.cfg vi zoo.cfg 修改这一行: dataDir=/soft/zookeeper-3.4.6/data 然后就可以运行了: cd bin ./zkServer.sh start 下面做一个最基本的Demo,返回一个固定的名称即可: 服务提

Vue/Egg大型项目开发(二)数据库设计

项目其他的实现都好说,不过为了梳理好思路和架构首先要搞定数据库 设计 这里推荐使用processon.com,因为是个在线的作图平台可以很方便的和他人合作. 设计出数据表后,就可以使用sequelize来生成相应的orm对象,然后sync到数据库中从而生成对应的数据表. 数据表类图 这是我项目的设计图,后期可能还会有修改. sequelize定义对应的orm对象 在model文件夹中定义对应的orm对象 比如user.js中如下,值得注意的是我们添加了一些额外字段以应对后期表中字段的添加. 代码

在大型项目上,Python 是个烂语言吗

Robert Love, Google Software Engineer and Manager on Web Search. Upvoted by Kah Seng Tay, I was the Head TA for a class taught in Java at MIT. I used… Robert has 10+ answers in Google Engineering. Man, I cannot imagine writing let alone maintaining a

怎么学习阅读大型项目的代码

第一章: 导论 ++++++++++++ 1.要养成一个习惯, 经常花时间阅读别人编写的高品质代码. 2.要有选择地阅读代码, 同时, 还要有自己的目标. 您是想学习新的模式|编码风格|还是满足某些需求的方法. 3.要注意并重视代码中特殊的非功能性需求, 这些需求也许会导致特殊的实现风格. 4.在现有的代码上工作时, 请与作者和维护人员进行必要的协调, 以避免重复劳动或产生厌恶情绪. 5.请将从开放源码软件中得到的益处看作是一项贷款, 尽可能地寻找各种方式来回报开放源码社团. 6.多数情况下,

如何阅读大型项目的代码?

本文转载自:http://blog.csdn.net/jk110333/article/details/7563718 Technorati 标签: 源码阅读 -------------------------------我是分割线的开始------------------------------------------ ++++++++++++++++++++ 第一章: 导论 ++++++++++++ 1.要养成一个习惯, 经常花时间阅读别人编写的高品质代码. 2.要有选择地阅读代码, 同时,