- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
标准模板STL
StandardTemplateLibrary
1. 概述 2
1.1. STL简介 2
1.2. 算法 2
1.3. 容器 3
1.4. 迭代器 3
1.5. 建议 4
2. LIST 4
2.1. 定义一个list 5
2.2. 用for循环来处理list中的元素 7
2.3. 用STL的通用算法for_each来处理list中的元素 8
2.4. 用STL的通用算法count()来统计list中的元素个数。 9
2.5. 用STL的通用算法count_if()来统计list中的元素个数 10
2.6. 使用count_if()的一个更加复杂的函数对象。 11
2.7. 使用STL通用算法find()在list中查找对象 13
2.8. 使用STL通用算法find_if()在list中有哪些信誉好的足球投注网站对象 13
2.9. 使用STL通用算法search在list中找一个序列 15
2.10. 使用list的成员函数sort()排序一个list。 16
2.11. 用list的成员函数插入元素到list中 17
2.12. List构造函数 18
2.13. 使用list成员函数从list中删除元素 19
2.14. 用list成员函数remove()从list中删除元素。 19
2.15. 使用STL通用算法remove()从list中删除元素 20
2.16. 使用STL通用算法stable_partition()和list成员函数splice()来划分一个list 22
2.17. 结论 25
2.18. 在field中使用STL 25
2.19. 参考书目 26
3. UsingSTL 26
3.1. STL概述 26
要点 26
头文件 27
名字空间 27
3.2. 迭代器 28
3.3. 迭代器的类型 28
3.3.1. 指针迭代器 28
3.3.2. 容器迭代器 29
3.3.3. 常量迭代器 30
3.3.4. 使用迭代器编程 30
3.3.5. 输入迭代器 31
3.3.6. 输出迭代器 31
3.3.7. 前推迭代器 32
3.3.8. 随机访问迭代器 32
3.3.9. 迭代器技术 32
3.4. 函数和函数对象 36
函数和断言 36
函数对象 37
发生器函数对象 39
发生器函数类对象 40
绑定器函数对象 42
否定函数对象 43
3.5. 总结:使用标准模板库(STL) 43
概述
STL简介
STL(StandardTemplateLibrary,标准模板库)是惠普实验室开发的一系列软件的统称。它是由AlexanderStepanov、MengLee和DavidRMusser在惠普实验室工作时所开发出来的。现在虽说它主要出现在C++中,但在被引入C++之前该技术就已经存在了很长的一段时间。
STL的代码从广义上讲分为三类:algorithm(算法)、container(容器)和iterator(迭代器),几乎所有的代码都采用了模板类和模版函数的方式,这相比于传统的由函数和类组成的库来说提供了更好的代码重用机会。在C++标准中,STL被组织为下面的13个头文件:algorithm、deque、functional、iterator、vector、list、map、memory、numeric、queue、set、stack和utility。以下笔者就简单介绍一下STL各个部分的主要特点。
算法
大家都能取得的一个共识是函数库对数据类型的选择对其可重用性起着至关重要的作用。举例来说,一个求方根的函数,在使用浮点数作为其参数类型的情况下的可重用性肯定比使用整型作为它的参数类性要高。而C++通过模板的机制允许推迟对某些类型的选择,直到真正想使用模板或者说对模板进行特化的时候,STL就利用了这一点提供了相当多的有用算法。它是在一个有效的框架中完成这些算法的——你可以将所有的类型划分为少数的几类,然后就可以在模版的参数中使用一种类型替换掉同一种类中的其他类型。
STL提供了大约100个实现算法的模版函数,比如算法for_each将为指定序列中的每一个元素调用指定的函数,stable_sort以你所指定的规则对序列进行稳定性排序等等。这样一来,只要我们熟悉了STL之后,许多代码可以被大大的化简,只需要通过调用一两个算法模板,就可以完成所需要的功能并大大地提升效率。
算法部分主要由头文件algorithm,numeric和functional组成。algorithm是所有STL头文件中最大的一个(尽管它很好理解),它是由一大堆模版函数组成的,可以认为每个函数在很大程度上都是独立的,其中常用到的功能范围涉及到比较、交换、查找、遍历操作、复制、修改、移除、反转、排序、合并等等。numeric体积很小,只包括几个在序列上面
文档评论(0)