容器与迭代器

STL是标准C++的组成,不熟悉STL不叫懂C++,我比较赞成这个说法的。

容器和迭代器是STL中的两个重要的概念。

这里摘述D.S.Malik的《数据结构——C++版》中的一句话:

每一个容器(序列或者关联)都包括一个typedef iterator。

这句话阐述了容器与迭代器之间的一个十分重要的关系,即:

容器中是有绑定迭代器的,或者说,容器内置了迭代器(实际用的是typedef)。

看如下代码:

#include <iostream>
#include <list>
#include <deque>
#include <vector>
using namespace std;

int main(){
	list<int> l;
	list<int>::iterator ite1; 
	vector<int> v;
	vector<int>::iterator ite2;
	deque<int> d;
	deque<int>::iterator ite3;
	return 0;
}
可以看到,list,vector和deque都内置了iterator,我们使用的时候直接按模式使用就可以了。

有点要注意,有很多容器是没有内置的,比如queue,这和容器的特点有关,queue根本就不提供遍历的特点,所以不提共itarator是可以理解的。


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值