美文网首页
GeekBand class6

GeekBand class6

作者: 0ffa31abb8f8 | 来源:发表于2016-11-27 18:54 被阅读0次

1.alloc gcc采用这种办法分配内存,省去了无用的开支。

2.迭代器

迭代器提供对一个容器中的对象的访问方法,并且定义了容器中对象的范围。迭代器就如同一个指针。事实上,C++的指针也是一种迭代器。但是,迭代器不仅仅是指针,因此你不能认为他们一定具有地址值。例如,一个数组索引,也可以认为是一种迭代器。

迭代器有各种不同的创建方法。程序可能把迭代器作为一个变量创建。一个STL容器类可能为了使用一个特定类型的数据而创建一个迭代器。作为指针,必须能够使用*操作符类获取数据。你还可以使用其他数学操作符如++。典型的,++操作符用来递增迭代器,以访问容器中的下一个对象。如果迭代器到达了容器中的最后一个元素的后面,则迭代器变成past-the-end值。使用一个past-the-end值得指针来访问对象是非法的,就好像使用NULL或为初始化的指针一样。

提示

STL不保证可以从另一个迭代器来抵达一个迭代器。例如,当对一个集合中的对象排序时,如果你在不同的结构中指定了两个迭代器,第二个迭代器无法从第一个迭代器抵达,此时程序注定要失败。这是STL灵活性的一个代价。STL不保证检测毫无道理的错误。

迭代器的类型

对于STL数据结构和算法,你可以使用五种迭代器。下面简要说明了这五种类型:

·Input iterators提供对数据的只读访问。

·Output iterators提供对数据的只写访问

·Forward iterators提供读写操作,并能向前推进迭代器。

·Bidirectional iterators提供读写操作,并能向前和向后操作。

·Random access iterators提供读写操作,并能在数据中随机移动。

尽管各种不同的STL实现细节方面有所不同,还是可以将上面的迭代器想象为一种类继承关系。从这个意义上说,下面的迭代器继承自上面的迭代器。由于这种继承关系,你可以将一个Forward迭代器作为一个output或input迭代器使用。同样,如果一个算法要求是一个bidirectional

迭代器,那么只能使用该种类型和随机访问迭代器。

指针迭代器

正如下面的小程序显示的,一个指针也是一种迭代器。该程序同样显示了STL的一个主要特性——它不只是能够用于它自己的类类型,而且也能用于任何C或C++类型。Listing 1, iterdemo.cpp, 显示了如何把指针作为迭代器用于STL的find()算法来搜索普通的数组。

相关文章

  • GeekBand class6

    1.alloc gcc采用这种办法分配内存,省去了无用的开支。 2.迭代器 迭代器提供对一个容器中的对象的访问方法...

  • C++线下测试回顾

    [题目地址](https://github.com/GeekBand/GeekBand-CPP-1501-Home...

  • iOS开发--事件监听处理

    这是我个人的学习笔记 , 如有不同见解欢迎评论交流 .( GeekBand-极客班 http://geekband...

  • python(Class6)

    使用描述符对实例属性做类型检查 __get__, __set__, __delete__

  • 2017泰营听录~class6

    2017泰国静修营——道次第28—Class6 0:00:00-0:12:46 休息时间 好了,我们要开始了。来自...

  • 2020-3-25

    1.阿里云7天打卡,class6 Java算法太难了(我根本就没学过) 2.老外想让跟我exchange pict...

  • GeekBand C++面向对象高级编程(上) Thrid We

    GeekBand C++面向对象高级编程(上) Thrid Week 面向对象编程(Object Oriented...

  • GeekBand 系统设计与实践 First Week

    GeekBand 系统设计与实践 First Week 硅谷公司及系统设计介绍 System Design的 试的...

  • 泰国静修营CLASS6

    我很多年没有看医生了,最近找了一个很好的医生,西方和自然疗法都很懂,看了一年多了。最近她说不想做医生了:因为她的先...

  • GeekBand C++ Week1 Notes

    GeekBand C++ Week1 Notes A.OOP-面向对象编程 1基础:C语言 -变量variable...

网友评论

      本文标题:GeekBand class6

      本文链接:https://www.haomeiwen.com/subject/hmnipttx.html