zoukankan      html  css  js  c++  java
  • stl中Iterators的基本用法

    C++ Iterators(迭代器)

    迭代器可被用来访问一个容器类的所包函的全部元素,其行为像一个指针。举一个例子,你可用一个迭代器来实现对vector容器中所含元素的遍历。有这么几种迭代器如下:

    迭代器 描述
    input_iterator 提供读功能的向前移动迭代器,它们可被进行增加(++),比较与解引用(*)。
    output_iterator 提供写功能的向前移动迭代器,它们可被进行增加(++),比较与解引用(*)。
    forward_iterator 可向前移动的,同时具有读写功能的迭代器。同时具有input和output迭代器的功能,并可对迭代器的值进行储存。
    bidirectional_iterator 双向迭代器,同时提供读写功能,同forward迭代器,但可用来进行增加(++)或减少(--)操作。
    random_iterator 随机迭代器,提供随机读写功能.是功能最强大的迭代器, 具有双向迭代器的全部功能,同时实现指针般的算术与比较运算。
    reverse_iterator 如同随机迭代器或双向迭代器,但其移动是反向的。(Either a random iterator or a bidirectional iterator that moves in reverse direction.)(我不太理解它的行为)

    第种容器类都联系于一种类型的迭代器。第个STL算法的实现使用某一类型的迭代器。举个例子,vector容器类就有一个random-access随机迭代器,这也意味着其可以使用随机读写的算法。既然随机迭代器具有全部其它迭代器的特性,这也就是说为其它迭代器设计的算法也可被用在vector容器上。

    如下代码对vector容器对象生成和使用了迭代器:

      vector<int> the_vector;   vector<int>::iterator the_iterator;    for( int i=0; i < 10; i++ )     the_vector.push_back(i);    int total = 0;   the_iterator = the_vector.begin();   while( the_iterator != the_vector.end() ) {     total += *the_iterator;     the_iterator++;   }   cout << "Total=" << total << endl; 
    提示:通过对一个迭代器的解引用操作(*),可以访问到容器所包含的元素。     
  • 相关阅读:
    为什么要用全文搜索引擎:全文搜索引擎 VS 数据库管理系统
    大数据学习路线之hive存储格式
    web测试教程之JavaScript中的变量
    Java学习中面向过程与面向对象的优缺点
    Java教程之Java反射
    Python技术基础知识点:OS模块的应用
    软件测试教程——概念解析及常用方法概说
    UI设计师必备技能 网页中的色彩搭配(色彩篇)
    UI技术分享 如何提高自己的设计视野
    JavaScript学习指南分享
  • 原文地址:https://www.cnblogs.com/ma6174/p/2376191.html
Copyright © 2011-2022 走看看