文章目录
条款26:尽可能延后变量定义式的出现时间
请记住
- 尽可能延后变量定义式的出现。这样做可增加程序的清晰度并改善程序效率。
我的理解
除非是在该变量只在循环中被赋值,否则请延后变量声明的时间,越晚越好。
条款27:尽量少做转型动作
请记住
- 如果可以,尽量避免转型,特别是在注重效率的代码中避免dynamic_casts。如果有个设计需要转型动作,试着发展无需转型的替代设计。
- 如果转型是必要的,试着将它隐藏于某个函数背后。客户随后可以调用该函数,而不需将转型放进他们自己的代码内。
- 宁可使用C+±style(新式)转型,不要使用旧式转型。前者很容易辨识出来,而且也比较有着分门别类的执掌。
我的理解
C++提供四种新式转型,分别为:
- const_cast<T>:移除常量性
- dynamic_cast<T>:别用,消耗大
- reinterpret_cast<T>:低级转型,很少使用
- static_cast<T>:除了const转型外其余的转型用这个
条款28:不要返回一个指向对象内部的指针
请记住
- 避免返回handles(包括reference、指针、迭代器)指向对象内部。遵守这个条款可增加封装性,帮助const成员函数的行为像个const,并将发生“虚吊号码牌”(dangling handles)的可能性降至最低。
我的理解
不要这么做,因为这么做会破坏封装,而且可能会出现对象被回收后,handles指向奇怪的位置
条款29:为“异常安全”而努力是值得的
请记住
- 异常安全函数(Exception-safe functions)即使发生异常也不会泄漏资源或允许任何数据结构败坏。这样的函数区分为三种可能的保证:基本型、强烈型、不抛异常型。
- “强烈保证”往往能够以copy-and-swap实现出来,但“强烈保证”并非对所有函数都可实现或具备现实意义。
- 函数提供的“异常安全保证”通常最高只等于其所调用之各个函数的“异常安全保证”中的最弱者。
我的理解
保证,指的是如果成功,就是成功,如果失败,那么保持一致性,回复到失败前的状态。
条款30:透彻了解inline的内内外外
请记住
- 将大多数inlining限制在小型、被频繁调用的函数身上。这可使日后的调试过程和二进制升级更容易,也可使潜在的代码膨胀问题最小化,是程序的速度提升机会最大化。
- 不要只因为function templates出现在头文件,就将它们声明为inline。
我的理解
inline适用于较短的、经常被调用的函数,函数模板与inline没有直接关系
条款31:将文件间的编译依存关系降至最低
请记住
- 支持“编译依存性最小化”的一般构想是:相依于声明式,不要相依于定义式。基于此构想的两个手段是Handle classes和Interface classes。
- 程序库头文件应该以“完全且仅有声明式”(full and declaration-only forms)的形式存在。这种做法不论是否涉及templates都适用。
我的理解
重点是只声明,不定义,要做到这一点,要么用指针指向声明的类进行操作,要么用派生类继承进行操作,二者分别是Handle classes和Interface classes。