首页 > 其他 > 详细

begin end rbegin rend 迭代器

时间:2021-03-29 00:00:42      阅读:33      评论:0      收藏:0      [点我收藏+]
位置

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 rbegin rend 迭代器

原文:https://blog.51cto.com/14982125/2675631

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!