Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1537786
  • 博文数量: 465
  • 博客积分: 8915
  • 博客等级: 中将
  • 技术积分: 6365
  • 用 户 组: 普通用户
  • 注册时间: 2010-07-30 15:05
文章分类

全部博文(465)

文章存档

2017年(33)

2016年(2)

2015年(4)

2014年(29)

2013年(71)

2012年(148)

2011年(178)

分类: C/C++

2012-11-16 15:35:52

传世经典书丛

More Effective C++35个改善编程与设计的有效方法(中文版)

[]Scott Meyers

侯捷

978-7-121-12570-6

20111月出版

价:59.00

16

336

Effective C++之后,Scott Meyers 1996 推出这本续集。条款变得比较少,页数倒是多了一些,原因是这次选材比第一集更高阶,尤其是第5 章。Meyers 将此章命名为技术(techniques),并明白告诉你,其中都是一些patterns,例如virtual constructorssmart pointersreference countingproxy classesdouble dispatching……这一章的每个条款篇幅都达15~30 页之多,实在让人有山重水复疑无路,柳暗花明又一村之叹。

虽然出版年代稍嫌久远,但本书并没有第2 版,原因是当其出版之时(1996),C++ Standard已经几乎定案,本书即依当时的标准草案而写,其与现今的C++标准规范几乎相同。而且可能变化的几个弹性之处,Meyers也都有所说明与提示。读者可以登录作者提供的网址,看看上下两集的勘误与讨论(数量之多,令人惊恐。幸好多是技术讨论或文字斟酌,并没有什么重大误失)。

More Effective C++ 的荣耀

这是一本多方面发人深省的 C++ 书籍:不论在你偶尔用到的语言特性上,或是在你自以为十分熟悉的语言特性上。只有深刻了解 C++ 编译器如何解释你的代码,你才有可能用C++ 语言写出健壮的软件。本书是协助你获得此等层级的了解过程中,一份极具价值的资源。读过本书之后,我感觉像是浏览了 C++ 编程大师所检阅过的代码,并获得许多极具价值的洞见。

——Fred Wild, Vice President of Technology,

Advantage Software Technologies

本书内含大量重要的技术,这些技术是撰写优良 C++ 程序所不可或缺的。本书解释如何设计和实现这些观念,以及潜伏在其他某些替代方案中的陷阱。本书亦含晚些加入的C++特性的详细说明。任何人如果想要好好地运用这些新特性,最好买一本并且放在随手可得之处,以备查阅。

——Christopher J. Van Wyk, Professor

Mathematics and Computer Science, Drew University

这是一本具备工业强度的最佳书籍。对于已经阅读过 Effective C++ 的人,这是完美的续集。

——Eric Nagler, C++ Instructor and Author,

University of California Santa Cruz Extension

More Effective C++ 是一本无微不至且很有价值的书籍,是Scott 第一本书Effective C++ 的续集。我相信每一位专业的C++ 软件开发人员都应该读过并记忆Effective C++ More Effective C++ 两本书内的各种招式,以及其中重要(而且有时候不可思议)的语言的方方面面。我强烈推荐这两本书给软件开发人员、测试人员、管理人员……,每个人都可以从Scott 专家级的知识与卓越的表达能力中获益。

——Steve Burkett, Software Consultant

C++ 是一门难学易用的语言!

C++ 的难学,不仅在其广博的语法、语法背后的语义、语义背后的深层思维、深层思维背后的对象模型;C++ 的难学,还在于它提供了4种不同(相辅相成)的编程思维模型:procedural-basedobject-basedobject-orientedgeneric paradigm

世上没有白吃的午餐。又要有效率,又要有弹性,又要前瞻望远,又要回溯相容,又要能治大国,又要能烹小鲜,学习起来当然就不可能太简单。

在如此庞大复杂的机制下,万千使用者前赴后继的动力是:一旦学成,妙用无穷。

C++ 相关书籍之多,车载斗量,如天上繁星,如过江之鲫。广博如四库全书者有之(The C++ Programming LanguageC++ Primer),深奥如重山复水者有之(The Annotated C++ Reference Manual, Inside the C++ Object Model),细说历史者有之(The Design and Evolution of C++, Ruminations on C++),独沽一味者有之(Polymorphism in C++, Genericity in C++),独树一帜者有之(Design Patterns, Large Scale C++ Software Design, C++ FAQs),程序库大全有之(The C++ Standard Library),另辟蹊径者有之(Generic Programming and the STL),工程经验之累积亦有之(Effective C++, More Effective C++, Exceptional C++)。

这其中,工程经验之累积对已具 C++ 相当基础的程序员而言,有着致命的吸引力与立竿见影的帮助。Scott Meyers Effective C++ More Effective C++ 是此类佼佼,Herb Sutter Exceptional C++ 则是后起之秀。

这类书籍的一个共同特色是轻薄短小,并且高密度地纳入作者浸淫于 C++/OOP 领域多年而广泛的经验。它们不但开扩读者的视野,也为读者提供各种 C++/OOP 常见问题或易犯错误的解决模型。某些小范围主题诸如base classes 中使用 virtual destructor”operator= 传回 *this reference”,可能在百科型 C++ 语言书籍中亦曾概略提过,但此类书籍以深度探索的方式,让我们了解问题背后的成因、最佳的解法,以及其他可能的牵扯。至于大范围主题,例如smart pointersreference countingproxy classesdouble dispatching,基本上已属design patterns的层级!

这些都是经验的累积和心血的结晶!

我很高兴将以下两本优秀书籍,规划为一个系列,以郑重的形式呈现给您:

1.    Effective C++ 2/e, by Scott Meyers, AW 1998

2.    More Effective C++, by Scott Meyers, AW 1996

本书不但与英文版页页对译,保留索引,并加上译注、交叉索引 、读者服务

这套书将对于您的程序设计生涯带来重大帮助。翻译这套书籍的过程中,我感觉来自技术体会上的极大快乐。我祈盼(并相信)您在阅读此书时拥有同样的心情。

侯捷 2003/03/07 于台湾新竹

jjhou@jjhou.com

http://www.jjhou.com

本书保留大量简短易读之英文术语,时而中英并陈。以下用语请读者特别注意:

英文术语       本书译词       英文术语       本书译词

argument 自变量   i.e. 实参)      instantiated     实例化、具现化

by reference    传址       library     程序库

by value  传值       resolve    决议

dereference     解引(i.e. 解参考)    parameter       参数   i.e. 形参)

evaluate   评估、核定    type 型别   i.e. 类型)

instance   实例             

译注:借此版面提醒读者,本书之中如果出现条款5”这样的参考指示,指的是本书条款5;如果出现条款E5”这样的参考指示,E 是指 Effective C++ 2/e

C++ 程序员而言,日子似乎有点过于急促。虽然只商业化不到 10 年,C++却俨然成为几乎所有主要计算环境的系统程序语言霸主。面临程序设计方面极具挑战性问题的公司和个人,不断投入 C++ 的怀抱。而那些尚未使用 C++ 的人,最常被询问的一个问题则是:你打算什么时候开始用 C++C++ 标准化已经完成,其所附带的标准程序库幅员广大,不仅涵盖 C 函数库,也使之相形见绌。这么一个大型程序库使我们有可能在不必牺牲移植性的情况下,或是在不必从头撰写常用算法和数据结构的情况下,完成琳琅满目的各种复杂程序。C++ 编译器的数量不断增加,它们所供应的语言性质不断扩充,它们所产生的代码质量也不断改善。C++ 开发工具和开发环境愈来愈丰富,威力愈来愈强大,健壮(robust)的程度也愈来愈高。商业化程序库几乎能够满足各个应用领域中的编程需求。

一旦语言进入成熟期,我们对它的使用经验也就愈来愈多,我们所需要的信息也就随之改变了。1990 年人们想知道 C++ 是什么东西。到了 1992 年,他们想知道如何运用它。如今 C++ 程序员问的问题更高级:我如何能够设计出适应未来需求的软件?我如何能够改善代码的效率而不折损正确性和易用性?我如何能够实现语言不能直接支持的精巧功能?

这本书中我要回答这些问题,以及其他许多类似问题。

本书将告诉你如何更具实效地设计并实现 C++ 软件:让它行为更正确,面对异常时更健壮、更有效率、更具移植性,将语言特性发挥得更好,更优雅地调整适应,在“混合语言”开发环境中运作得更好,更容易被正确运用,更不容易被误用。简单地说就是如何让软件更好。

本书内容分为 35 个条款。每个条款都在特定主题上精简摘要出 C++ 程序设计社区所积累的智能。大部分条款以准则的形式呈现,随附的说明则阐述这条准则为什么存在,如果不遵循会发生什么后果,以及什么情况下可以合理违反该准则。

所有条款被我分为数大类。某些条款关心特定的语言性质,特别是你可能少有使用经验的一些新性质。例如条款9~15专注于exceptions(就像Tom CargillJackReevesHerb Sutter 所发表的那些杂志文章一样)。其他条款解释如何结合语言的不同特性以达成更高阶目标。例如条款25~31描述如何限制对象的个数或诞生地点,如何根据一个以上的对象类型产生出类似虚函数的东西,如何产生smart pointers等。其他条款解决更广泛的题目。条款16~24 专注于效率上的议题。不论哪一个条款,提供的都是与其主题相关且意义重大的做法。在 More Effective C++ 一书中你将学习到如何更实效、更精锐地使用C++。大部分C++ 教科书中对语言性质的大量描述,只能算是本书的一个背景信息而已。

这种处理方式意味着,你应该在阅读本书之前便熟悉 C++。我假设你已了解classes(类)、保护层级(protection levels)、虚函数、非虚函数,我也假设你已通晓 templates exceptions 背后的概念。我并不期望你是一位语言专家,所以涉及较罕见的 C++ 特性时,我会进一步解释。

本书所谈的C++

我在本书所谈、所用的C++,是 ISO/ANSI 标准委员会于199711月完成的C++ 国际标准最后草案(Final Draft International Standard)。这暗示了我所使用的某些语言特性可能并不在你的编译器(s)支持能力之列。别担心,我认为对你而言唯一所谓的“新”特性,应该只有 templates,而 templates 如今几乎已是各家编译器的必备功能。我也运用 exceptions,并大量集中于条款9~15。如果你的编译器(s)未能支持 exceptions,没什么大不了,这并不影响本书其他部分带给你的好处。但是,听我说,即使你不需要用到 exceptions,亦应阅读条款9~15,因为那些条款(及其相关篇幅)检验了某些不论什么场合下你都应该了解的主题。

我承认,就算标准委员会授意某一语言特性或是赞同某一实务做法,并非就保证该语言特性已出现在目前的编译器上,或该实务做法已可应用于既有的开发环境上。一旦面对“标准委员会所议之理论”和“真正能够有效运作之实务”间的矛盾,我便将两者都加以讨论,虽然我其实更重视实务。由于两者我都讨论,所以当你的编译器(s)和C++ 标准不一致时,本书可以协助你,告诉你如何使用目前既有的架构来模拟编译器(s)尚未支持的语言特性。而当你决定将一些原本绕道而行的解决办法以新支持的语言特性取代时,本书亦可引导你。

注意当我说到编译器(s)时,我使用复数。不同的编译器对C++ 标准的满足程度各不相同,所以我鼓励你在至少两种编译器(s)平台上发展代码。这么做可以帮助你避免不经意地依赖某个编译器专属的语言延伸性质,或是误用某个编译器对标准规格的错误阐释。这也可以帮助你避免使用过度先进的编译器技术,例如,独家厂商才做得出的某种语言新特性。如此特性往往实现得不够精良(臭虫多,要不就表现得迟缓,或是两者兼具),而且C++ 社区往往对这些特性缺乏使用经验,无法给你应用上的忠告。雷霆万钧之势固然令人兴奋,但当你的目标是要产生可靠的代码,恐怕还是步步为营(并且能够与人合作)的好。

本书用了两个你可能不太熟悉的C++ 性质,它们都是晚些才加入C++ 标准之中的。某些编译器支持它们,但如果你的编译器不支持,你可以轻易地用你所熟悉的其他性质来模拟它们。

第一个性质是bool类型,其值必为关键词true false。如果你的编译器尚未支持 bool,有两个方法可以模拟它。第一个方法是使用一个 global enum

enum bool { false, true };

这允许你将参数为 bool int 的不同函数加以重载(overloading)。缺点是,内建的“比较操作符(comparison operators)”如 ==<>=,等仍旧返回 ints。所以以下代码的行为不如我们所预期:

void f(int);

void f(bool);

int x, y;

...

f( x < y ); // 调用 f(int),但其实它应该调用 f(bool)

一旦你改用真正支持 bool 的编译器,这种 enum 近似法可能会造成程序行为的改变。

另一种做法是利用 typedef 来定义 bool,并以常量对象作为 true false

typedef int bool;

const bool false = 0;

const bool true = 1;

这种手法与传统的 C/C++ 语义兼容。使用这种仿真法的程序,在移植到一个支持有bool 类型的编译器平台之后,行为并不会改变。缺点则是无法在函数重载(overloading)时区分 bool int。以上两种近似法都有道理,请选择最适合你的一种。

第二个新性质,其实是4 个转型操作符:static_castconst_castdynamic_castreinterpret_cast。如果你不熟悉这些转型操作符,请翻到条款2仔细阅读其中内容。它们不只比它们所取代的 C 旧式转型做得更多,也更好。书中任何时候当我需要执行转型动作,我都使用新式的转型操作符。

C++ 拥有比语言本身更丰富的东西。是的,C++ 还有一个伟大的标准程序库(见条款E49)。我尽可能使用标准程序库所提供的 string 类型来取代 char* 指针,而且我也鼓励你这么做。string objects 并不比char*-based 字符串难操作,它们的好处是可以免除你大部分的内存管理工作。而且如果发生 exception 的话(见条款910),string objects 比较不会出现 memory leaks(内存泄漏)问题。实现良好的string 类型甚至可和对应的 char* 比赛效率,而且可能会赢(条款29 会告诉你其中的故事)。如果你不打算使用标准的string 类型,你当然会使用类似string 的其他 classes,是吧?是的,用它,因为任何东西都比直接使用 char* 来得好。

我将尽可能使用标准程序库提供的数据结构。这些数据结构来自StandardTemplate Library(“STL”——见条款35)。STL包含bitsetsvectorslistsqueuesstacksmapssets,以及更多东西,你应该尽量使用这些标准化的数据结构,不要情不自禁地想写一个自己的版本。你的编译器或许没有附带STL给你,但不要因为这样就不使用它。感谢 Silicon Graphics 公司的热心,你可以从 SGI STL网站下载一份免费产品,它可以和多种编译器配合使用。

如果你目前正在使用一个内含各种算法和数据结构的程序库,而且用得相当愉快,那么就没必要只为了“标准”两个字而改用 STL。然而如果你在“使用 STL”和“自行撰写同等功能的代码”之间可以选择,你应该让自己倾向使用STL。记得代码的复用性吗?STL(以及标准程序库的其他组件)之中有许多代码是十分值得重复运用的。

惯例与术语

任何时候如果我谈到 inheritance(继承),我的意思是 public inheritance(见条款E35)。如果我不是指 public inheritance,我会明确地指出。绘制继承体系图时,我对 base-derived 关系的描述方式,是从 derived classes base classes 画箭头。例如,下面是条款31的一张继承体系图。

这样的表现方式和我在 Effective C++ 第一版(注意,不是第二版)所采用的习惯不同。现在我决定使用这种最被广泛接受的箭头画法:从 derived classes 画往base classes,而且我很高兴事情终能归于一统。此类示意图中,抽象类(abstractclasses,例如上图的 GameObject)被我加上阴影而具体类(concrete classes,例如上图的 SpaceShip)未加阴影。

Inheritance(继承)机制会引发“pointers(或 references)拥有两个不同的类型”的议题,两个类型分别是静态类型(static type)和动态类型(dynamic type)。Pointer reference 的“静态类型”是指其声明时的类型,“动态类型”则由它们实际所指的对象来决定。下面是根据上图所写的一个例子:

GameObject *pgo = // pgo 的静态类型是 GameObject*

new SpaceShip; // 动态类型是 SpaceShip*

Asteroid *pa = new Asteroid; // pa 的静态类型是 Asteroid*

// 动态类型也是 Asteroid*

pgo = pa; // pgo 的静态类型仍然(永远)是 GameObject*

// 至于其动态类型如今是 Asteroid*

GameObject& rgo = *pa; // rgo 的静态类型是 GameObject

// 动态类型是 Asteroid

这些例子也示范了我喜欢的一种命名方式。pgo 是一个 pointer-to-GameObjectpa 是一个 pointer-to-Asteroidrgo 是一个 reference-to-GameObject。我常常以此方式来为 pointer reference 命名。

我很喜欢两个参数名称:lhs rhs,它们分别是“left-hand side”和“right-handside”的缩写。为了了解这些名称背后的基本原理,请考虑一个用来表示分数(rational numbers)的 class

class Rational { ... };

如果我想要一个“用来比较两个 Rational objects”的函数,我可能会这样声明:

bool operator==(const Rational& lhs, const Rational& rhs);

这使我得以写出这样的代码:

Rational r1, r2;

...

if (r1 == r2) ...

在调用 operator== 的过程中,r1 位于“==”左侧,被绑定于 lhsr2 位于“==”右侧,被绑定于 rhs

我使用的其他缩写名称还包括:ctor 代表“constructor”,dtor 代表“destructor”,RTTI 代表 C++ runtime type identification 的支持(在此性质中,dynamic_cast是最常被使用的一个组件)。

当你分配内存而没有释放它,你就有了memory leak(内存泄漏)问题。Memoryleaks C C++ 中都有,但是在 C++ 中,memory leaks所泄漏的还不只是内存,因为 C++ 会在对象被产生时,自动调用 constructors,而 constructors 本身可能亦配有资源(resources)。举个例子,考虑以下代码:

class Widget { ... }; // 某个 class——它是什么并不重要。

Widget *pw = new Widget; // 动态分配一个 Widget 对象。

... // 假设 pw 一直未被删除(deleted)。

这段代码会泄漏内存,因为pw 所指的Widget 对象从未被删除。如果Widget constructor 分配了其他资源(例如 file descriptorssemaphoreswindow handlesdatabase locks),这些资源原本应该在 Widget 对象被销毁时释放,而现在也像内存一样都泄漏掉了。为了强调在 C++ memory leaks 往往也会泄漏其他资源,我在书中常以 resource leaks 一词取代 memory leaks

你不会在本书中看到许多 inline 函数。并不是我不喜欢 inlining,事实上我相信 inline 函数是 C++ 的一项重要性质。然而决定一个函数是否应被 inlined,条件十分复杂、敏感,而且与平台有关(见条款E33)。所以我尽量避免 inlining,除非其中有个关键点非使用 inlining 不可。当你在本书中看到一个 non-inline 函数,并不意味我认为把它声明为 inline 是个坏主意,而只是说,它“是否为 inline”与

当时讨论的主题无关。

有一些传统的 C++ 性质已明确地被标准委员会排除。这样的性质被列于语言的最后撤除名单,因为新性质已经加入,取代那些传统性质的原本工作,而且做得更好。这本书中我会找出被撤除的性质,并说明其取代者。你应该避免使用被撤除的性质,但是过度在意倒也不必,因为编译器厂商为了挽留其客户,会尽力保存向下兼容性,所以那些被撤除的性质大约还会存活好多年。

所谓 client,是指你所写代码的客户。或许是某些人(程序员),或许是某些物(classes functions)。举个例子,如果你写了一个 Date class(用来表现生日、最后期限、耶稣再次降临日等),任何使用了这个 class 的人,便是你的 client。任何一段使用了 Date class 的代码,也是你的 clientsClients 是重要的,事实上

clients 是游戏的主角。如果没有人使用你写的软件,你又何必写它呢?你会发现我很在意如何让 clients 更轻松,通常这会导致你的行事更困难,因为好的软件“以客为尊”。如果你讥笑我太过滥情,不妨反躬自省一下。你曾经使用过自己写的 classes functions 吗?如果是,你就是你自己的 client,所以让 clients 更轻松,其实就是让自己更轻松,利人利己。

当我讨论class templatesfunction templates,以及由它们所产生出来的 classes functions 时,请容我保留偷懒的权利,不一一写出 templates 和其 instantiations(实例)之间的差异。举个例子,如果 Array 是个 class template,有个类型参数T,我可能会以 Array 代表此 template 的某个特定实例(instantiation)——虽然其实Array 才是正式的 class 名称。同样道理,如果swap 是个 function template,有个类型参数 T,我可能会以 swap 而非 swap 表示其实例。如果这样的简短表示法在当时情况下不够清楚,我便会在表示 template 实例时加上 template参数。

臭虫报告,意见提供,内容更新

我尽力让这本书技术精准、可读性高,而且有用,但是我知道一定仍有改善空间。如果你发现任何错误——技术性的、语言上的、错别字,或任何其他问题——请告诉我,我会试着在本书重印时修正。如果你是第一位告诉我的人,我会很高兴将你的大名记录到本书致谢文(acknowledgments)内。如果你有改善建议,我也非常欢迎。

我将继续收集 C++ 程序设计的实效准则。如果你有任何这方面的想法并愿意与我分享,我会十分高兴。请将你的建议、你的见解、你的批评,以及你的臭虫报告,寄至:

Scott Meyers

c/o Editor-in-Chief, Corporate and Professional Publishing

Addison-Wesley Publishing Company

1 Jacob Way

Reading, MA 01867

U. S. A.

或者你也可以发送电子邮件到 mec++@awl.com

我整理了一份本书第一次印刷以来的修订记录,其中包括错误修正、文字修润,以及技术更新。你可以从本书网站取得这份记录及与本书相关的其他信息。你也可以通过 anonymous FTP,从 ftp.awl.com cp/mec++ 目录中取得它。如果你希望拥有这份数据,但又无法上网,请寄申请函到上述地址,我会邮寄一份给你。

这篇序文够长的了,让我们开始正题吧。

  

译序(侯捷)                                                                            

导读(Introduction                                                           

基础议题(Basics                                                                   

条款1:仔细区别 pointers references                                    

Distinguish between pointers and references.

条款2:最好使用 C++ 转型操作符                                           

Prefer C++-style casts.

条款3:绝对不要以多态(polymorphically)方式处理数组               

Never treat arrays polymorphically.

条款4:非必要不提供 default constructor                                   

Avoid gratuitous default constructors.

操作符(Operators                                                           

条款5:对定制的类型转换函数保持警觉                                

Be wary of user-defined conversion functions.

条款6:区别 increment/decrement 操作符的

前置(prefix)和后置(postfix)形式                                 

Distinguish between prefix and postfix forms of increment

and decrement operators.

条款7:千万不要重载&&,||, 操作符                                         

Never overload &&, ||, or ,.

条款8:了解各种不同意义的 new delete                              

Understand the different meanings of new and delete

 

异常(Exceptions                                                             

条款9:利用 destructors 避免泄漏资源                                     

Use destructors to prevent resource leaks.

条款10:在 constructors 内阻止资源泄漏(resource leak               

Prevent resource leaks in constructors.

条款11:禁止异常(exceptions)流出 destructors 之外              

Prevent exceptions from leaving destructors.

条款12:了解抛出一个 exception”传递一个参数

调用一个虚函数之间的差异                            

Understand how throwing an exception differs from

passing a parameter or calling a virtual function.

条款13:以 by reference 方式捕捉 exceptions                                  

Catch exceptions by reference.

条款14:明智运用 exception specifications                                 

Use exception specifications judiciously.

条款15:了解异常处理(exception handling)的成本                        

Understand the costs of exception handling.

 

效率(Efficiency                                                                    

条款16:谨记 80-20 法则                                                  

Remember the 80-20 rule.

条款17:考虑使用 lazy evaluation(缓式评估)                        

Consider using lazy evaluation.

条款18:分期摊还预期的计算成本                                            

Amortize the cost of expected computations.

条款19:了解临时对象的来源                                            

Understand the origin of temporary objects.

条款20:协助完成返回值优化(RVO                                  

Facilitate the return value optimization.

条款21:利用重载技术(overload)避免隐式类型转换(implict type conversions

Overload to avoid implicit type conversions.

条款22:考虑以操作符复合形式(op=)取代其独身形式(op       

Consider using op= instead of stand-alone op.

条款23:考虑使用其他程序库                                            

Consider alternative libraries.

条款24:了解 virtual functionsmultiple inheritancevirtual base classes

runtime type identification 的成本                                 

Understand the costs of virtual functions, multiple inheritance,

virtual base classes, and RTTI.

 

技术(Techniques, Idioms, Patterns                                    

条款25:将 constructor non-member functions 虚化              

Virtualizing constructors and non-member functions.

条款26:限制某个 class 所能产生的对象数量                                  

Limiting the number of objects of a class.

条款27:要求(或禁止)对象产生于 heap 之中                       

Requiring or prohibiting heap-based objects.

条款28Smart Pointers(智能指针)                                        

条款29Reference counting(引用计数)                                         

条款30Proxy classes(替身类、代理类)                                

条款31:让函数根据一个以上的对象类型来决定如何虚化                

Making functions virtual with respect to more than one object.

杂项讨论(Miscellany                                                             

条款32:在未来时态下发展程序                                               

Program in the future tense.

条款33:将非尾端类(non-leaf classes)设计为

抽象类(abstract classes                                             

Make non-leaf classes abstract.

条款34:如何在同一个程序中结合 C++ C                                  

Understand how to combine C++ and C in the same program.

条款35:让自己习惯于标准 C++ 语言                                      

Familiarize yourself with the language standard.

推荐读物                                                                                   

auto_ptr 实现代码                                                               

索引(一)(General Index                                                      

索引(二)(Index of Example ClassesFunctionsand Templtes             

 

阅读(1055) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~