Effective STL中文版

出版社:电子工业出版社
出版日期:2013-5
ISBN:9787121201257
作者:[美] Scott Meyers
页数:220页

章节摘录

版权页:   公平地讲,STL的实现者很清楚,begin、end(以及类似的函数,如size)都是被频繁使用的函数,所以他们尽最大可能提高其效率。他们几乎肯定会使用inline来编译这些函数,并且努力改善这些函数的代码,尽可能让大多数编译器都能够将循环中的计算提到外面来,以避免重复计算。然而,实践表明,实现者并不是每次都能成功,当他们不能成功的时候,因使用算法而避免重复计算所得到的性能优势,比起手写循环来就非常值得了。 但这只是很次要的性能增益。最主要的是,类库实现者可以根据他们对于容器实现的了解程度对遍历过程进行优化,这是库的使用者所难以做到的。例如,deque中的对象(在内部)通常被存放在一个或多个固定大小的数组中。对于这些数组,基于指针的遍历比基于迭代器的遍历要快得多。但是只有库的实现者才可以使用基于指针的遍历,因为只有他们才知道内部数组的大小,才知道如何从一个数组转移到另一个数组。有些STL包含的算法实现考虑到了deque的内部数据结构,这些算法实现比“普通”的算法实现快了20%多。 这里的要点是,STL算法的实现未必一定都针对deque(或其他特定的容器类型)进行了优化,但无论如何实现者肯定比你更了解内部的实现细节,他们可以在算法实现中充分利用这些知识。如果你避开算法调用而使用自己的手写循环,你也就放弃了这些算法实现可能提供的优化手段。 其次的性能增益在于,除了一些不太重要的算法以外,其他几乎所有的STL算法都使用了复杂的计算机科学算法,有些科学算法非常复杂,并非一般的C++程序员所能够达到的。例如,你很难在算法级别上写出比STL的sort或类似的算法更有效的代码(见第31条);STL中针对排序区间的查找算法也非常优秀(见第34条和第45条);即使是那些普通的任务,比如从连续内存的容器中删除一些对象,使用erase.remove习惯用法所获得的性能也比一般程序员编写的循环要高效得多(见第9条)。 如果效率方面的原因还不能说服你,那么也许正确性对你更有吸引力。当你编写循环代码的时候,最要紧的莫过于要保证你所使用的迭代器(a)都是有效的:(b)并且指向你所希望的地方。例如,假设有一个数组(可能是由于某个遗留下来的C APl的原因,见第l6条),而你要让每个数组元素加上41,然后把它插入到一个deque的前部。

内容概要

Scott Meyers,世界顶级C++软件开发技术权威之一。他是两本畅销书Effective C++和More Effective C++的作者,以前曾经是C++ Report的专栏作家。他经常为C/C++ Users Journal和Dr. Dobb's Journal撰稿,也为全球范围内的客户做咨询活动。他也是Advisory Boards for NumeriX LLC和InfoCruiser公司的成员。他拥有Brown University的计算机科学博士学位。
潘爱民,任职于阿里云计算有限公司,担任阿里云OS首席架构师。长期从事软件和系统技术的研究与开发工作,撰写了大量软件技术文章,著译了多部经典计算机图书,在国内外学术刊物上发表了30多篇文章。曾经任教于北京大学和清华大学(兼职)。后进入工业界,先后任职于微软亚洲研究院、盛大网络发展有限公司和阿里云计算有限公司。目前也是工信部移动操作系统专家组成员。
潘爱民获得了数学学士学位和计算机科学博士学位,主要研究领域包括软件设计、信息安全、操作系统和互联网技术。

书籍目录

引言...............................................................................................................1
1 容器..........................................................................................9
第1 条:慎重选择容器类型。............................................................... 9
第2 条:不要试图编写独立于容器类型的代码。.................................... 12
第3 条:确保容器中的对象拷贝正确而高效。....................................... 16
第4 条:调用empty 而不是检查size()是否为0。................................... 18
第5 条:区间成员函数优先于与之对应的单元素成员函数。............................ 20
第6 条:当心C++编译器最烦人的分析机制。.................................................... 26
第7 条:如果容器中包含了通过new 操作创建的指针,切记在容器对象析构前将
指针delete 掉。......................................................................... 28
第8 条:切勿创建包含auto_ptr 的容器对象。......................................... 32
第9 条:慎重选择删除元素的方法。............................................................... 34
第10 条:了解分配子(allocator)的约定和限制。........................................... 38
第11 条:理解自定义分配子的合理用法。............................................. 44
第12 条:切勿对STL 容器的线程安全性有不切实际的依赖。......................... 47
2 vector 和string .....................................................................................51
第13 条:vector 和string 优先于动态分配的数组。............................................. 51
第14 条:使用reserve 来避免不必要的重新分配。............................................. 53
第15 条:注意string 实现的多样性。.......................................................... 55
第16 条:了解如何把vector 和string 数据传给旧的API。.................................... 60
第17 条:使用“swap 技巧”除去多余的容量。................................................... 63
第18 条:避免使用vector。................................................................................. 64
3 关联容器..........................................................................................................................67
第19 条:理解相等(equality)和等价(equivalence)的区别。...................................... 67
第20 条:为包含指针的关联容器指定比较类型。........................................ 71
第21 条:总是让比较函数在等值情况下返回false。.............................................. 74
第22 条:切勿直接修改set 或multiset 中的键。............................................... 77
第23 条:考虑用排序的vector 替代关联容器。............................................... 82
第24 条:当效率至关重要时,请在map::operator[ ]与map::insert 之间谨慎做出选择。..... ...................... 87
第25 条:熟悉非标准的散列容器。........................................................................... 91
4 迭代器..............................................................................................................95
第26 条:iterator 优先于const_iterator、reverse_iterator 及const_reverse_iterator。.....95
第27 条:使用distance 和advance 将容器的const_iterator 转换成iterator。............ 98
第28 条:正确理解由reverse_iterator 的base()成员函数所产生的iterator 的用法。.... ...................... 101
第29 条:对于逐个字符的输入请考虑使用istreambuf_iterator。......................... 103
5 算法...............................................................................................................................106
第30 条:确保目标区间足够大。....................................................................... 107
第31 条:了解各种与排序有关的选择。................................................................110
第32 条:如果确实需要删除元素,则需要在remove 这一类算法之后调用erase。...........115
第33 条:对包含指针的容器使用remove 这一类算法时要特别小心。.....................118
第34 条:了解哪些算法要求使用排序的区间作为参数。.................................. 121
第35 条:通过mismatch 或lexicographical_compare 实现简单的忽略大小写的字符
串比较。.................................................................. 124
第36 条:理解copy_if 算法的正确实现。............................................................. 128
第37 条:使用accumulate 或者for_each 进行区间统计。.................................... 130
6 函数子、函数子类、函数及其他...........................................................................135
第38 条:遵循按值传递的原则来设计函数子类。..................................... 135
第39 条:确保判别式是“纯函数”。................................................................. 138
第40 条:若一个类是函数子,则应使它可配接。............................................... 141
第41 条:理解ptr_fun、mem_fun 和mem_fun_ref 的来由。................................. 145
第42 条:确保less与operator<具有相同的语义。........................................ 148
7 在程序中使用STL ..............................................................................................152
第43 条:算法调用优先于手写的循环。................................................................. 152
第44 条:容器的成员函数优先于同名的算法。........................................................ 159
第45 条:正确区分count、find、binary_search、lower_bound、upper_bound 和
equal_range。....... ...................... 161
第46 条:考虑使用函数对象而不是函数作为STL 算法的参数。.................................. 168
第47 条:避免产生“直写型”(write-only)的代码。................................................ 172
第48 条:总是包含(#include)正确的头文件。................................................. 175
第49 条:学会分析与STL 相关的编译器诊断信息。..................................... 176
第50 条:熟悉与STL 相关的Web 站点。........................................................... 183
参考书目........................................................................................189
附录A 地域性与忽略大小写的字符串比较.................................................193
附录B 对Microsoft 的STL 平台的说明..........................................202

编辑推荐

《Effective STL中文版:50条有效使用STL的经验》适合广大编程爱好者及程序员阅读。也适合作为高校相关专业教材,供学生学习和参考。

作者简介

《Effective STL中文版:50条有效使用STL的经验》是EffectiveC++的第3卷,被评为“值得所有C++程序员阅读的C++书籍之一”。《Effective STL中文版:50条有效使用STL的经验》详细讲述了使用STL的50条指导原则,并提供了透彻的分析和深刻的实例,实用性极强,是C++程序员必备的基础书籍。C++的标准模板库(STL)是革命性的,要用好STL并不容易。《Effective STL中文版:50条有效使用STL的经验》作者ScottMeyers揭示了专家总结的一些关键规则,包括专家们总是采用的做法,以及专家们总是避免的做法。通过这些规则,STL程序员可以最大限度地使用STL。


 Effective STL中文版下载 精选章节试读 更多精彩书评



发布书评

 
 


精彩书评 (总计2条)

  •     Scott Meyers 写这本书似乎有些勉强了。和《Effective C++》不同,读这本书基本没有那种豁然开朗的感觉,尽管内容组织和叙述都很清晰,但是在新标准下本书所涉及的很多知识都已缺失了时效性。
  •     《STL源码剖析》讲原理,那么这本《Effective STL》就是讲实用技术!这是继《STL源码剖析》之后,我看的第二本STL书籍,书中一些知识借鉴《STL源码剖析》的内容,没有源码级那么难懂,但是讲解的东西却非常的实用,接地气。比如为何调用 empty 而不是 size, 如何在循环中删除容器元素,使用“swap"除去多余容量,相等和等价的区别,erese-remove的搭配使用,函数子的配接等等。从效率和使用细节举例进行讲述,读完感觉真心收获不少。

精彩短评 (总计28条)

  •     书本身不错,译者也很专业,但是,我还是灰常BS这种翻译版和原版对不上页码的情况,对errata简直就是自寻死路。。。
  •     Scott Meyers 写这本书似乎有些勉强了。和《Effective C++》不同,读这本书基本没有那种豁然开朗的感觉,尽管内容组织和叙述都很清晰,但是在新标准下本书所涉及的很多知识都已缺失了时效性。
  •     不得不读的好书,刚买了一本收藏。 PS:这个版本很适合收藏,纸质特好。
  •     内容一般 不如看STL源码剖析
  •     需要更新到C++ 11
  •     effective系列还是不错滴
  •     值得收藏,学习STL必看。
  •     感觉干货不如其他几本多,也有可能是我水平高了,没有耳目一新的感觉
  •     同英文版
  •     内容就不用说了, 作为纸质书, 纸张也很好, 值得购买
  •     很有建设性的意见,不过遗憾的是C++11没有写到里面
  •     毫无悬念。。学C++的必须要看的
  •     梅耶的这一系列都是干货,收获良多~
  •     说实在的,很多地方还没有看明白。但是看明白的地方都让我很震撼,有一种豁然开朗的感觉。
  •     细节,不过书还是有点老了,好多书中提到的没有加入C++标准里面的,现在都已经写在C++11里面了。
  •     绝对经典,想高效地利用STL,这本书必看
  •     写的还行。不过看起来那些高级STL用法在real world中用的真不多啊。
  •     STL 进阶必看
  •     该更新了。
  •     找工作前,匆匆看过。还需要翻翻。
  •     重新刷一次leetcode发现自己毕业以后越来越菜了
  •     nice
  •     潘爱民老师,Scott Meyers老师,还有什么可以犹豫的,看吧,受益匪浅
  •     Effective系列的书都是经典
  •     好书,日后写STL时,肯定还要再读一遍。
  •     粗略看了一遍,不是书不好,是我太菜了………………
  •     内容和质量都不错,之前评论说差的差点让我没买,亚马逊太实在,要放某网站那些早删了
  •     看过老版的,非常好的书,推荐。
 

外国儿童文学,篆刻,百科,生物科学,科普,初中通用,育儿亲子,美容护肤PDF图书下载,。 零度图书网 

零度图书网 @ 2024