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++帮助文档
相关推荐
樱木Plus7 小时前
深拷贝(Deep Copy)和浅拷贝(Shallow Copy)
c++
blasit2 天前
笔记:Qt C++建立子线程做一个socket TCP常连接通信
c++·qt·tcp/ip
肆忆_3 天前
# 用 5 个问题学懂 C++ 虚函数(入门级)
c++
不想写代码的星星3 天前
虚函数表:C++ 多态背后的那个男人
c++
端平入洛5 天前
delete又未完全delete
c++
端平入洛6 天前
auto有时不auto
c++
哇哈哈20217 天前
信号量和信号
linux·c++
多恩Stone7 天前
【C++入门扫盲1】C++ 与 Python:类型、编译器/解释器与 CPU 的关系
开发语言·c++·人工智能·python·算法·3d·aigc
蜡笔小马7 天前
21.Boost.Geometry disjoint、distance、envelope、equals、expand和for_each算法接口详解
c++·算法·boost
超级大福宝7 天前
N皇后问题:经典回溯算法的一些分析
数据结构·c++·算法·leetcode