标准模板库-LIST.doc

标准模板库-LIST.doc

ID:28555203

大小:87.50 KB

页数:23页

时间:2018-12-11

标准模板库-LIST.doc_第1页
标准模板库-LIST.doc_第2页
标准模板库-LIST.doc_第3页
标准模板库-LIST.doc_第4页
标准模板库-LIST.doc_第5页
资源描述:

《标准模板库-LIST.doc》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库

1、标准模板库-LIST倚天佑2006年7月5日目录0前言.31定义一个list32使用list的成员函数push_back和push_front插入一个元素到list中43list的成员函数empty()44用for循环来处理list中的元素55用STL的通用算法for_each来处理list中的元素76用STL的通用算法count_if()来统计list中的元素个数87使用count_if()的一个更加复杂的函数对象。98使用STL通用算法find()在list中查找对象119使用STL通用算法find_if()在list中搜索对象1210使

2、用STL通用算法search在list中找一个序列1311使用list的成员函数sort()排序一个list。1412用list的成员函数插入元素到list中1513List构造函数1614使用list成员函数从list中删除元素1615用list成员函数remove()从list中删除元素。1716使用STL通用算法remove()从list中删除元素1817使用STL通用算法stable_partition()和list成员splice()来划分一个list1918结论2219参考书目:230前言.本文以List容器为例子,介绍了STL的

3、基本内容,从容器到迭代器,再到普通函数,而且例子丰富,通俗易懂。不失为STL的入门文章,新手不容错过!这篇文章是关于C++语言的一个新的扩展——标准模板库的(StandardTemplateLibrary),也叫STL。当我第一次打算写一篇关于STL的文章的时候,我不得不承认我当时低估了这个话题的深度和广度。有很多内容要含盖,也有很多详细描述STL的书。因此我重新考虑了一下我原来的想法。我为什么要写这篇文章,又为什么要投稿呢?这会有什麽用呢?有再来一篇关于STL的文章的必要吗?当我翻开MusserandSaini的页时,我看到了编程时代在我面

4、前消融。我能看到深夜消失了,目标软件工程出现了。我看到了可维护的代码。一年过去了,我使用STL写的软件仍然很容易维护。让人吃惊的是其他人可以没有我而维护的很好!然而,我也记得在一开始的时候很难弄懂那些技术术语。一次,我买了Musser&Saini,每件事都依次出现,但是在那以前我最渴望得到的东西是一些好的例子。当我开始的时候,作为C++一部分的Stroustrup还没出来,它覆盖了STL。因此我想写一篇关于一个STL程序员的真实生活的文章可能会有用。如果我手上有一些好的例子的话,特别是象这样的新题目,我会学的更快。另外一件事是STL应该很好用

5、。因此,理论上说,我们应该可以马上开始使用STL。什麽是STL呢?STL就是StandardTemplateLibrary,标准模板库。这可能是一个历史上最令人兴奋的工具的最无聊的术语。从根本上说,STL是一些“容器”的集合,这些“容器”有list,vector,set,map等,STL也是算法和其他一些组件的集合。这里的“容器”和算法的集合指的是世界上很多聪明人很多年的杰作。STL的目的是标准化组件,这样你就不用重新开发它们了。你可以仅仅使用这些现成的组件。STL现在是C++的一部分,因此不用额外安装什麽。它被内建在你的编译器之内。因为ST

6、L的list是一个简单的容器,所以我打算从它开始介绍STL如何使用。如果你懂得了这个概念,其他的就都没有问题了。另外,list容器是相当简单的,我们会看到这一点。这篇文章中我们将会看到如何定义和初始化一个list,计算它的元素的数量,从一个list里查找元素,删除元素,和一些其他的操作。要作到这些,我们将会讨论两个不同的算法,STL通用算法都是可以操作不止一个容器的,而list的成员函数是list容器专有的操作。这是三类主要的STL组件的简明纲要。STL容器可以保存对象,内建对象和类对象。它们会安全的保存对象,并定义我们能够操作的这个对象的接

7、口。放在蛋架上的鸡蛋不会滚到桌上。它们很安全。因此,在STL容器中的对象也很安全。我知道这个比喻听起来很老土,但是它很正确。STL算法是标准算法,我们可以把它们应用在那些容器中的对象上。这些算法都有很著名的执行特性。它们可以给对象排序,删除它们,给它们记数,比较,找出特殊的对象,把它们合并到另一个容器中,以及执行其他有用的操作。STLiterator就象是容器中指向对象的指针。STL的算法使用iterator在容器上进行操作。Iterator设置算法的边界,容器的长度,和其他一些事情。举个例子,有些iterator仅让算法读元素,有一些让算法

8、写元素,有一些则两者都行。Iterator也决定在容器中处理的方向。你可以通过调用容器的成员函数begin()来得到一个指向一个容器起始位置的iterator。你可

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。