begin end rbegin rend 迭代器
作者:互联网
位置
str.begin();指向字符串的第一个字符的位置
str.end();指向字符串的最后一个字符的后一个位置;
str.rbegin();指向字符串的最后一个字符的位置;
str.rend();指向第一个字符串的前一个位置;
void test()
{
string str = "1234";
cout << *str.rbegin() << endl;
cout << *str.begin() << endl;
cout << *--str.rend() << endl;
cout << *--str.end() << endl;
}
移动方向
str.begin()++;向后面的位置移动(从首字符向尾字符移动);
str.rbegin()++;向前面的位置移动(从尾字符向首字符移动);
> 迭代器(iterator)有时又称光标(cursor)是程序设计的软件设计模式,可在容器对象(container,例如链表或数组)上遍访的接口,设计人员无需关心容器对象的内存分配的实现细节。
*迭代器:
设计模式---》元素访问的一种设计模式
所有容器都需要遵循相同的设计规范
所有的容器迭代器的使用方式都是相同的
怎么使用?
迭代器的使用方式和指针类似
设计规范:
1.begin迭代器:指向第一个元素的位置;
2.end迭代器:指向最后一个元素的末尾;
3.访问数据:通过解引用完成:,->
4.迭代器移动:++移动到下一个元素的位置,移动到上一个元素的位置;
5.位置的判断:支持!=,==
有些容器具有反向迭代器
6.rbegin迭代器:指向最后一个元素的位置;
7.rend迭代器:指向第一个元素的前一个位置**
标签:字符,begin,end,rend,迭代,位置,str,移动,指向 来源: https://blog.51cto.com/14982125/2675631