首页 > 代码库 > 《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