C++——迭代器简介

##一、什么是迭代器?##
  迭代器(iterator)其实和STL息息相关,STL里所有的容器都有迭代器的概念。迭代器有只读或可写之分,也有随机或顺序之分。其实可以把迭代器理解成特别的指针,它具有指针基本的操作(解引用*,自加++,自减--,指向结构体成员->等操作)。迭代器的特别之处在于写基于迭代器的算法时不需要知道容器的类型,迭代器对不同的容器提供了效果一致的使用方法,<algorithm>中的诸多函数也正是基于迭代器来实现的。
##二、怎么获取迭代器?##
  通常从容器中获取迭代器可以使用std::begin()std::end()两个函数,分别获得容器的beginend
  用法如下:对于容器containerstd::begin(container)std::end(container)即能获得一对迭代器。
  除了这两个函数以外,还有std::cbegin()(c for constant),std::rbegin()(r for reverse),std::crbegin()以及它们对应的end函数,依次来获得const的,倒序的,const且倒序的迭代器。
  而为了使所有的容器支持迭代器,正如中所述需要满足一些算法的泛用性,上述函数对于数组也可以取得对应的一对迭代器。
  当然除了使用上述函数以外,

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值