我是靠谱客的博主 痴情金毛,最近开发中收集的这篇文章主要介绍c++顺序容器访问、删除元素,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

一、访问元素

1.可以使用所有顺序容器都有的front和唯独forward_list没有的back来直接获得的首元素和尾元素的引用(begin和end解引用间接获得),其中back就是最后一个元素(end是最后一个元素的下一个位置)

vector<int>a = { 4,5,9 };
auto num1 = *a.begin(), num2 = a.front();

2.提供快速随机访问的容器也都提供下标运算符,但要保证下标不越界

3.如果希望确保下标合法,可以使用at成员函数,如果下标越界会报错

vector<int>a = { 4,5,9 };
a[1] == a.at(1);
a.at(3);			//运行时报错(不是写完就报错)

4.在容器中访问元素的成员函数(front、back、下标、at)返回的都是引用,如果是const对象则是const的引用

vector<int>a = { 4,5,9 };
auto& num = a.front();
num = 7;        //num是首元素的引用,可以改变
auto numm = a.front();
numm = 9;       //numm是首元素的拷贝

二、删除元素

1.可以使用pop_back(forward_list不支持)和pop_front(vector、string不支持)来删除尾、首元素

2.除了forward_list特殊的earse外,earse用法如下:可以删除由一个迭代器指定的单个元素(迭代器是尾后迭代器则行为未定义),也可以删除由一对迭代器指定的范围内的所有元素(可以是尾后迭代器)

3.可以用clear来删除全部元素或者erase的第二种形式

vector<int>a = { 4,5,9 };
a.erase(a.begin());
a.erase(a.begin(), a.end());
a.clear();

4.对于删除单个元素,返回指向被删除元素之后元素的迭代器(包括尾后迭代器);对于范围删除,返回指向最后一个被删除元素之后元素的迭代器,若最后一个参数是尾后迭代器也返回尾后迭代器;clear返回void

最后

以上就是痴情金毛为你收集整理的c++顺序容器访问、删除元素的全部内容,希望文章能够帮你解决c++顺序容器访问、删除元素所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(55)

评论列表共有 0 条评论

立即
投稿
返回
顶部