c++迭代器

 

把迭代器理解为广义上的指针,换句话就是可能封装了一个指针,也可能就是一个操作类似指针的一个对象;

迭代器的作用是可以独立于标准库的算法:

比方说模版的作用是把类型抽离出来,只专注算法. 迭代器的作用是把容器抽离出来 , 例如:

//输出的模版函数
/*
print 不需要知道容器类型, 只需要迭代器能递增,以及获取值即可;
模版的作用是把类型抽离出来.迭代器的作用是把某种类型容器抽离出来;

下面的 T 为一个迭代器,至于是哪个容器或者哪个的迭代器都无所谓,只要
迭代器重载了 != , ++ , * 运算符即可. 
*/


template <typename T>
void print( T b,  T e)               //接受2个迭代器
{
    while(b != e)                    
        cout << *b++ << ' ';         //迭代都支持 ++ , * 重载
    cout <<endl;
}



//main.cpp

vector<int> vi = {1,2,3,1,2,3,3,4,5,4,5,6,7};
deque<int> li = {1,2,3,1,2};

print(vi.begin(),vi.end());   //print 不需要知道到底是vector还是deque

print(li.begin(),li.end()); 

//又如 std::sort,排序函数不需要知道到底是vector 还是deque,还是其他容器

std::sort(vi.begin(),vi.end());

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值