
最 低 价:¥14.70
| “这是Effective C++的第三卷,棒极了!” ——Herb Sutter,ISO/ANSI C++标准委员会的独立咨询顾问和秘书 “值得C++程序员必读的C++书籍并不多。Effecitive STL正是其中之一。” ——Thomas Becker,Zephyr Associates公司的首席软件工程师,C/C++Users Journal的专栏作家 |
| 引言 第1章 容器 第1条:慎重选择容器类型。 第2条:不要试图编写独立于容器类型的代码。 第3条:确保容器中的对象拷贝正确而高效。 第4条:调用empty而不是检查size()是否为0。 第5条:区间成员函数优先于与之对应的单元素成员函数。 第6条:当心C++编译器最烦人的分析机制。 第7条:如果容器中包含了通过new操作创建的指针,切记在容器对象析构前将指针delete掉。 第8条:切勿创建包含auto_ptr的容器对象。 第9条:慎重选择删除元素的方法。 第10条:了解分配子(allocator)的约定和限制。 第11条:理解自定义分配子的合理用法。 第12条:切勿对STL容器的线程安全性有不切实际的依赖。 第2章 vector和strin 第13条:vector 和string优先于动态分配的数组。 第14条:使用reserve来避免不必要的重新分配。 第15条:注意string 实现的多样性。 第16条:了解如何把vector和string数据传给旧的API。 第17条:使用“swap技巧”除去多余的容量。 第18条:避免使用vector 第3章 关联容器 第19条:理解相等(equality)和等价(equivalence)的区别。 第20条:为包含指针的关联容器指定比较类型。 第21条:总是让比较函数在等值情况下返回false。 第22条:切勿直接修改set或multiset中的键。 第23条:考虑用排序的vector替代关联容器。 第24条:当效率至关重要时,请在map::operator[]与map::insert之间谨慎做出选择。 第25条:熟悉非标准的哈希容器。 第4章 迭代器 第26条:iterator优先于const_iterator、reverse_iterator以及const_reverse_iterator。 第27条:使用distance和advance将容器的const_iterator转换成iterator。 第28条:正确理解由reverse_iterator的base()成员函数所产生的iterator的用法。 第29条:对于逐个字符的输入请考虑使用istreambuf_iterator。 第5章 算法 第30条:确保目标区间足够大。 第31条:了解各种与排序有关的选择。 第32条:如果确实需要删除元素,则需要在remove这一类算法之后调用erase。 第33条:对包含指针的容器使用remove这一类算法时要特别小心。 第34条:了解哪些算法要求使用排序的区间作为参数。 第35条:通过mismatch或lexicographical_compare实现简单的忽略大小写的字符串比较。 …… 第6章 函数子、函数子类、函数及其他 第7章 在程序中使用STL 参考书目 附录A:地域性与忽略大小写的字符串比较 附录B:对Microsoft的STL平台的说明 |
商品评论(0条)