Effective C++改善程序与设计的55个具体做法 5. 实现

条款 26: 尽可能延后变量定义式的出现时间

尽可能延后变量定义式的出现。这样做可增加程序的清晰度并改善程序效率。

条款 27: 尽量少做转型动作

如果可以,尽量避免转型,特别是在注重效率的代码中避免 dynamic_casts 。如果有个设计需要转型动作,试着发展无需转型的替代设计。

如果转型是必要的,试着将它隐藏于某个函数背后。客户随后可以调用该函数,而不需将转型放进他们自己的代码内。

可使用 C++-style (新式)转型,不要使用旧式转型。前者很容易辨识出来,而且也比较有着分门别类的职掌。

个人理解:掌握c++ style 的转型方法

canst_cast<T>(expression):通常被用来将对象的常量性转除(castawaytheconstness)。它也是唯一有此能力的C++-style转型操作符。

dynamic_cast<T>(expression):dynamic_cast是用来检查两者是否有继承关系。因此该运算符实际上只接受基于类对象的指针和引用的类转换。C++标准转换运算符dynamic_cast - Ider - 博客园

reinterpret_cast<T>(expression):运算符是用来处理无关类型之间的转换;C++标准转换运算符reinterpret_cast - Ider - 博客园

static_cast<T>(expression):static_cast支持指向基类的指针和指向子类的指针之间的互相转换,static_cast真正用处并不在指针和引用上,而在基础类型和对象的转换上 。C++标准转换运算符static_cast - Ider - 博客园

条款 28: 避免返回 handles 指向对象内部成分

避免返回 handles (包括 references 、指针、迭代器)指向对象内部。遵守这个条款可增加封装性,帮助 const 成员函数的行为像个 const ,并将发生"虚吊号码牌" (dangling handles) 的可能性降至最低。

个人理解:一个是防止返回的是指针,用户空间可以操作成员对象的数据。另一个是如果生命周期结束,会发生空指针的情况;

条款 29: 为"异常安全"而努力是值得的

异常安全函数 (Exception-safe functions) 即使发生异常也不会泄漏资源或允许任何数据结构败坏。这样的函数区分为三种可能的保证:基本型、强烈型、不抛异常型。

"强烈保证"往往能够以 copy-and-swap 实现出来,但"强烈保证"并非对所有函数都可实现或具备现实意义。

函数提供的"异常安全保证"通常最高只等于其所调用之各个函数的"异常安全保证"中的最弱者。

个人理解:发生异常时,原来的资源被安全的释放,也不影响最初的业务逻辑;

条款 30: 透彻了解 inlining 的里里外外

将大多数 inlining 限制在小型、被频繁调用的函数身上。这可使日后的调试过程和二进制升级 (binary upgradability) 更容易,也可使潜在的代码膨胀问题最小化,使程序的速度提升机会最大化。

不要只因为 function templates 出现在头文件,就将它们声明为 inline。

个人理解:函数具体是否inlined还取决于调用方式,当使用指针调用的时候,即使你声明了inline还是会按照非inline函数调用

条款 31: 将文件间的编译依存关系降至最低

支持"编译依存性最小化"的一般构想是:相依于声明式,不要相依于定义式。基于此构想的两个手段是 Handle classes 和 Interface classes。

程序库头文件应该以"完全且仅有声明式" (full and declaration-only forms) 的形式存在。这种做法不论是否涉及 templates 都适用。

个人理解:高内聚/低耦合,相互耦合会导致编译时间比较长。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值