首页 > 后端开发 > C++ > 正文

c++ vector怎么用 c++ vector容器用法全解

冰火之心
发布: 2025-12-05 17:38:44
原创
480人浏览过
vector是C++ STL中常用的动态数组容器,支持自动内存管理、随机访问和动态扩容。通过#include 引入,可进行多种初始化如空构造、指定大小、列表初始化等。常用操作包括push_back、emplace_back添加元素,pop_back删除末尾元素,erase删除指定位置或区间元素,front和back访问首尾元素,size、empty、capacity获取容量信息,resize调整大小,reserve预分配空间。遍历方式有下标、迭代器和范围for循环,推荐使用const auto&避免拷贝。vector内部采用连续内存存储,支持O(1)随机访问,但中间插入删除为O(n),需注意性能影响。频繁扩容可通过reserve优化,避免深拷贝建议传引用参数。掌握vector的使用能显著提升编程效率与程序稳定性。

c++ vector怎么用 c++ vector容器用法全解

vector 是 C++ STL 中最常用的一种动态数组容器,它能自动管理内存,支持随机访问,并且可以动态扩容。相比普通数组,vector 更安全、更灵活,是日常编程中处理序列数据的首选工具

1. vector 的基本定义与初始化

要使用 vector,需要包含头文件 #include

vector v1; // 创建空的 int 类型 vector
vector v2(5); // 创建 5 个元素,初始值为 0.0
vector v3(3, 10); // 创建 3 个元素,每个都是 10
vector v4 = {1, 2, 3, 4}; // C++11 支持列表初始化
vector v5(v4); // 拷贝构造,v5 是 v4 的副本

也可以从数组或另一个容器构造:

int arr[] = {1, 2, 3};
vector v6(arr, arr + 3);

2. 常用操作函数说明

vector 提供了丰富的成员函数来操作数据。

立即学习C++免费学习笔记(深入)”;

添加元素:
  • v.push_back(x);:在末尾插入一个元素
  • v.emplace_back(x);:比 push_back 更高效,直接在末尾构造对象
删除元素:
  • v.pop_back();:删除最后一个元素(不返回值)
  • v.clear();:清空所有元素
  • v.erase(it);:删除指定迭代器位置的元素
  • v.erase(it1, it2);:删除一个区间 [it1, it2)
访问元素:
  • v[i]v.at(i):访问第 i 个元素(at 会做越界检查)
  • v.front();:返回第一个元素
  • v.back();:返回最后一个元素
容量与大小相关:
  • v.size();:当前元素个数
  • v.empty();:判断是否为空
  • v.capacity();:当前分配的存储空间大小
  • v.resize(n);v.resize(n, val);:调整大小
  • v.reserve(n);:预分配空间,避免频繁扩容
其他实用操作:
  • v.swap(v2);:交换两个 vector 的内容
  • swap(v, v2);:标准 swap 函数,效率高

3. 遍历 vector 的方法

有多种方式可以遍历 vector 中的元素。

Manus
Manus

全球首款通用型AI Agent,可以将你的想法转化为行动。

Manus 250
查看详情 Manus
下标遍历: for (int i = 0; i   cout } 迭代器遍历: for (auto it = v.begin(); it != v.end(); ++it) {
  cout }
范围 for 循环(推荐): for (const auto& x : v) {
  cout }

如果只是读取,建议使用 const auto& 避免拷贝;需要修改则用 auto&。

4. vector 的性能与注意事项

vector 内部使用连续内存存储,因此支持 O(1) 随机访问,但在中间插入/删除是 O(n) 操作,效率较低。

  • 频繁在末尾添加元素时,使用 reserve() 可减少内存重新分配次数
  • 避免在 vector 中间频繁 insert/erase,考虑 list 或 deque 是否更合适
  • vector 的扩容策略通常是成倍增长(如 2 倍),具体由编译器实现决定
  • 当 vector 被复制或作为参数传递时,会进行深拷贝,代价较高,建议传引用

例如:

void print(const vector& v) {
  for (int x : v) cout }

这样不会拷贝整个 vector,提高效率。

基本上就这些。vector 使用简单但功能强大,掌握好它的用法,能大幅提升编码效率和程序稳定性。

以上就是c++++ vector怎么用 c++ vector容器用法全解的详细内容,更多请关注php中文网其它相关文章!

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号