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++帮助文档
相关推荐
寻寻觅觅☆6 小时前
东华OJ-基础题-106-大整数相加(C++)
开发语言·c++·算法
fpcc6 小时前
并行编程实战——CUDA编程的Parallel Task类型
c++·cuda
ceclar1237 小时前
C++使用format
开发语言·c++·算法
lanhuazui108 小时前
C++ 中什么时候用::(作用域解析运算符)
c++
charlee448 小时前
从零实现一个生产级 RAG 语义搜索系统:C++ + ONNX + FAISS 实战
c++·faiss·onnx·rag·语义搜索
老约家的可汗8 小时前
初识C++
开发语言·c++
crescent_悦8 小时前
C++:Product of Polynomials
开发语言·c++
小坏坏的大世界9 小时前
CMakeList.txt模板与 Visual Studio IDE 操作对比表
c++·visual studio
乐观勇敢坚强的老彭9 小时前
c++寒假营day03
java·开发语言·c++
愚者游世10 小时前
brace-or-equal initializers(花括号或等号初始化器)各版本异同
开发语言·c++·程序人生·面试·visual studio