C++STL之vector

本文介绍了C++STL中的vector容器,包括size(), max_size(), capacity()等方法的使用,探讨了push_back(), pop_back(), insert()和erase()等操作,强调了迭代器在元素插入删除中的作用。还讲解了vector作为二维数组的使用方式,以及empty(), front(), back(), clear(), swap(), resize(), reserve()等常见方法,并鼓励通过实践加深理解。" 114569391,10545752,Java算法:判断正方形与矩形的位置关系,"['java', 'algorithm', 'math']

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

C++STL是C++标准模板库,一个非常强大的库,这个库是C没有的,也是C和C++的区别之一,这个库有多么强大呢,他含有很多容器,这些容器实际上就是各种数据结构,而只需要调用这些库就可以完成数据结构能完成功能。

向量容器 vector

vector是一个底层可扩容的容器,也是最常见的最长使用的STL容器之一,他和数组最大区别就是底层可以自动扩容,用的也是malloc函数进行扩容,我们今天来介绍一些他的常用方法。

size() :当然容器的元素个数

max_size() :当前容器能添加的最大元素个数

capacity() : 当前容器的容量

这三个方法放一起说一下,这三个函数看着好像很像,其实区别还是很大的,首先说一下max_size()这个方法就是说在当前系统中,创建的容器所能容纳的最大元素,这取决于内存的大小,而不是当前创建的容器的大小,这个其实并不常用。

说size()和capacity()之前我们首先要知道在vector创建的时候,有三个私有成员变量,

_first:指向第第一个元素的首地址

_last:指向最后一个元素的地址

_end:指向容器的最后地址的下一个地址

如下图所示:

这样看的话,size()和capacity()的区别是不是就很清楚了,我们在用代码实际看一下:

#include <iostream>
#include <vector>
using namespac
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值