C++之STL迭代器

  • 迭代器(iterator)是一个对象,常用它来遍历容器,即在容器中实现"取得下一个元素"的操作。不管容器是否直接提供了访问其对象的方法,通过迭代器都能够访问该容器中的元素,一次访问一个元素
  • 迭代器是STL的核心,它定义了哪些算法在哪些容器中可以使用,把算法和容器连接起来,使算法、容器和迭代器能够协同工作,实现强大的程序功能
  • 若某个容器要使用迭代器,它就必须定义迭代器。定义迭代器时,必须指定迭代器所使用的容器类型。比如,若定义了一个保存int类型元素的链表:
cpp 复制代码
list<int> L1;
// 为int类型的list容器指定迭代器的定义如下:
list<int>::iterator iter;
  • 完成该定义后,STL会自动将此迭代器转换成链表所需要的双向迭代器,该迭代器可以用于int型的list
  • 迭代器提供的主要操作如下:
cpp 复制代码
operator* 	返回当前位置的元素值
operator++ 	将迭代器前进到下一个元素位置
operator-- 	将迭代器后退到前一个元素位置
operator==或operator!= 	判定两个迭代器是否指向同一个位置
operator= 	为迭代器赋值
begin() 	指向容器起点(即第一个元素)位置
end() 	指向容器的结束点,结束点在最后一个元素之后
begin() 	指向按反向顺序的第一个元素位置
rend() 	指向按反向顺序的最后一个元素后的位置
  • 示例代码
cpp 复制代码
#include <iostream>
#include <list>
using namespace std;
int main(void){
    int i = 0;
    list<int> L1, L2, L3(10);
    list<int>::iterator iter;
    int a1[] = {100,90,80,70,60};
    int a2[] = {30,40,50,60,60,60,80};
    for(i=0; i<5; i++)
        L1.push_back(a1[i]);
    for(i=0; i<7; i++)
        L2.push_back(a2[i]);
    for(iter = L1.begin(); iter!=L1.end(); iter++){
        cout << *iter << "\t";
    }
    cout << endl;
    int sum = 0;
    //for(iter=--L2.end(); iter!=L2.begin(); iter--){
    iter = L2.end();
    do{
        iter--;
        cout << *iter << "\t";
        sum += *iter;
    }while(iter != L2.begin());
    cout << "\nL2: sum=" << sum << endl;
    int data = 0;
    for(iter=L3.begin(); iter!=L3.end(); iter++)
        *iter = data+=10;
    for(iter = L3.begin(); iter!=L3.end(); iter++){
        cout << *iter << "\t";
    }
    cout << endl;
    
    return 0;
}
        
  • STL中的迭代器可分为双向迭代器、前向迭代器、后向迭代器、输入迭代器和输出迭代器几种类型。前面介绍的迭代器属于双向迭代器,了解其他几种迭代器的用法,可以参考C++帮助文档
相关推荐
无限进步_21 小时前
C++异常机制:抛出、捕获与栈展开
开发语言·c++·安全
王老师青少年编程1 天前
csp信奥赛C++高频考点专项训练之前缀和&差分 --【一维前缀和】:宝石串
c++·前缀和·csp·高频考点·信奥赛·宝石串
梓䈑1 天前
【算法题攻略】模拟
c++·算法
vKd0Ff21L1 天前
如何在Dev-C++中设置TDM-GCC为默认编译器第九十一篇
java·jvm·c++
cany10001 天前
C++ -- 型号比对和constexpr
c++
楼田莉子1 天前
C++17新特性:结构化绑定/inline变量/if相关的变化
c++·后端·学习
翎沣1 天前
C++面向对象三大特性
开发语言·c++
无限进步_1 天前
【C++】C++11的类功能增强与STL变化
java·前端·数据结构·c++·后端·算法
小鱼️遨游1 天前
openCPU SDK 安装和第一次编译方法、注意事项
c++·opencpu·ml307
basketball6161 天前
C++ iostream 完全指南:从 cin/cout 到流式编程的奥秘
开发语言·c++