首页 > 代码库 > 《effective c++》读书笔记4
《effective c++》读书笔记4
条款41:了解隐式接口和编译期多态
n classes和templates都支持接口和多态
n 对classes而言接口是显式的,以函数签名为中心,多态则是通过虚函数发生于运行期。
n 对templates参数而言,接口是隐式的,奠基于有效表达式,多态则是通过template具现化和函数重载解析发生于编译器。
条款42:了解typename的双重意义
n 声明模板参数,前缀关键字class和typename可互换。
n 请使用关键字typename标识嵌套从属类型名称,但不得在基类或者成员初值列内以它作为基类修饰符。
条款43:学习处理模板化基类内的名称
模板也可以作为基类被继承,派生类的成员函数如果想访问基类的函数版本,可以使用三种方法:第一是在基类函数调用之前加上this->,第二是使用using 声明,第三个做法是,明白指出被调用的函数位于基类内。
条款44:将与参数无关的代码抽离模板
条款45:运用成员函数模板接受所有兼容类型
条款46:需要类型转换时请为模板定义非成员函数
n 当我们编写一个类模板,而它所提供之与此模板相关的函数支持所有参数之隐式类型转换,请将那些函数定义为类模板内部的友元函数。
条款47:使用traits类表现类型信息
n traits类使得类型相关信息在编译器可用,它们以模板和模板特化完成实现
n 整合重载技术后,traits类有可能在编译期对类型执行if…else…测试
条款48:模板元编程
n 模板元编程可将工作有运行期移往编译期,因而得以实现早期错误侦测和更高的执行效率。
条款49:了解new-handler行为
n set_new_handler允许客户指定一个函数,在内存分配无法获得满足时被调用。
条款50:了解new和delete的合理替换时机
替换operator new和operator delete的三个最常见的理由:
用来检测运用上的错误;
为了强化效能;
为了收集使用上的统计数据;
条款51:编写new和delete时需要固守常规
n operator new应该内含一个无穷循环,并在其中尝试分配内存,如果它无法满足内存需求,就该调用new-handler,它也应该有能力处理0字节的申请。class专属版本则还应该处理比正确大小更大的申请。
n operator delete应该在收到null指针时不做任何事。class专属版本还应该处理比正确大小更大的错误申请。
条款52:写了placement new也要写placement delete
当你写一个placement new,请确定也写出了对应的placement operator delete如果没有这样做,程序可能会发生隐微而时断时续的内存泄露。
当你声明placement new和placement delete,请确定不要无意识地遮掩了它们的正常版本。
条款53:不要轻忽编译器的警告
n 严肃对待编译器发出的警告信息,努力在你的编译器的最高警告级别下争取无任何警告的荣誉。
n 不要过度依赖编译器的报警能力,因为不同的编译器对待事物的态度并不相同,一旦移植到另外一个编译器上,你原本依赖的警告信息有可能消失。
条款54:让自己熟悉包括TR1在内的标准程序库
n C++标准程序库的主要机能由STL、iostream、locales组成,并包含C99标准程序库。
n TR1添加了智能指针、一般化函数指针,hash_based容器,正则表达式,以及另外的10个组件的支持。
n TR1自身只是一份规范,为获得TR1提供的好处,需要一份实物,一个好的实物来源是Boost
条款55:让自己熟悉Boost
Boost是一个社群,也是一个网站,致力于免费、源码开放、同僚复审的C++程序库开发。Boost在C++标准化过程中扮演深具影响力的角色。
Boost提供许多TR1组件实现品,以及其他许多程序库。
《effective c++》读书笔记4