博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
vector学习之迭代器begin, end, cbegin, cend, rbegin, rend, rcbegin, rcend
阅读量:2193 次
发布时间:2019-05-02

本文共 1633 字,大约阅读时间需要 5 分钟。

vector提供的迭代器有以下几种访问方式

begin, cbegin返回指向超始的迭代器

end,cend返回指向末尾的迭代器

rbegin,crbegin返回指向超始的逆向迭代器

rend,crend返回指向末尾的逆向迭代器

代码示例如下:

#include 
#include
using namespace std;void getIterator(){ vector
vec1 = {12, 32, 34 ,53, 56, 76, 78}; vector
::iterator it1 = vec1.begin(); while (it1 != vec1.end()) { cout << *it1 << "\t"; ++it1; } cout << endl; auto begin = vec1.begin(); auto last = vec1.end() - 1;//end()是最后一个元素的下一个位置,所以这里要向前移一个位置 *begin = 55; cout << "begin c= " << *begin << " end = " << *last << endl; auto it2 = vec1.begin(); while (it2 != vec1.end()) { cout << *it2 << "\t"; ++it2; } cout << endl; auto cbegin = vec1.cbegin(); auto cend = vec1.cend() - 1; //*cbegin = 88;//cbegin返回的是一个常量迭代器,不能修改他的值 cout << "cbegin = " << *cbegin << " cend = " << *cend << endl; cout << endl; auto rbegin = vec1.rbegin(); auto rend = vec1.rend() - 1;//rend返回的是容器第一个元素的前一个位置 cout << "rbegin = " << *rbegin << " rend = " << *rend << endl; *rbegin = 98;//修改最后一个元素的值 auto it3 = vec1.begin(); while (it3 != vec1.end()) { cout << *it3 << "\t"; ++it3; } cout << endl; auto crbegin = vec1.crbegin(); auto crend = vec1.crend() - 1; //*crbegin = 73;//crbegin返回最后一个常量迭代器,不能修改 cout << "crbegin = " << *crbegin << " crend = " << *crend << endl;}int main(){ //int = [-2147483648, 2147483647] getIterator(); cout << endl; cout << "Hello World!" << endl; return 0;}

运行结果:

cbegin, cend, crbegin, crend返回的是常量迭代器,不能通过迭代器修改vector元素的值。这4个函数是C++11里新增加的功能。

 

 

 

 

 

转载地址:http://afiub.baihongyu.com/

你可能感兴趣的文章
Java集合详解3:一文读懂Iterator,fail-fast机制与比较器
查看>>
Java集合详解4:一文读懂HashMap和HashTable的区别以及常见面试题
查看>>
Java集合详解5:深入理解LinkedHashMap和LRU缓存
查看>>
Java集合详解6:这次,从头到尾带你解读Java中的红黑树
查看>>
Java集合详解7:一文搞清楚HashSet,TreeSet与LinkedHashSet的异同
查看>>
Java集合详解8:Java集合类细节精讲,细节决定成败
查看>>
Java并发指南1:并发基础与Java多线程
查看>>
Java并发指南2:深入理解Java内存模型JMM
查看>>
Java并发指南3:并发三大问题与volatile关键字,CAS操作
查看>>
Java并发指南4:Java中的锁 Lock和synchronized
查看>>
Java并发指南5:JMM中的final关键字解析
查看>>
Java并发指南6:Java内存模型JMM总结
查看>>
Java并发指南7:JUC的核心类AQS详解
查看>>
Java并发指南8:AQS中的公平锁与非公平锁,Condtion
查看>>
Java网络编程和NIO详解6:Linux epoll实现原理详解
查看>>
Java网络编程和NIO详解7:浅谈 Linux 中NIO Selector 的实现原理
查看>>
Java网络编程与NIO详解8:浅析mmap和Direct Buffer
查看>>
Java网络编程与NIO详解10:深度解读Tomcat中的NIO模型
查看>>
Java网络编程与NIO详解11:Tomcat中的Connector源码分析(NIO)
查看>>
深入理解JVM虚拟机1:JVM内存的结构与消失的永久代
查看>>