Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >C++一分钟之-容器概览:vector, list, deque

C++一分钟之-容器概览:vector, list, deque

作者头像
Jimaks
发布于 2024-06-22 00:55:51
发布于 2024-06-22 00:55:51
15400
代码可运行
举报
文章被收录于专栏:大数据大数据
运行总次数:0
代码可运行

在C++的世界里,STL(Standard Template Library,标准模板库)为我们提供了丰富而强大的数据结构和算法,其中容器部分是开发中不可或缺的一部分。今天,我们将快速浏览三种常用且功能各异的序列容器:vectorlistdeque,探讨它们的特点、适用场景以及常见的使用误区与避免策略。

1. vector:动态数组

vector是C++中最常用的容器之一,它在内部表现为一个动态数组,能够高效地进行随机访问,但插入和删除非末尾元素可能较慢,因为这可能导致内存的重新分配和元素的复制。

常见问题与避免策略:

  • 内存重新分配:当vector容量不足以容纳新元素时,它会自动扩容,这个过程可能导致性能开销。可以通过reserve()预先分配足够的容量来避免频繁的内存重分配。
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
std::vector<int> vec;
vec.reserve(100); // 预先分配空间
  • 插入和删除:尽量减少在vector中间的插入和删除操作,尤其是当这些操作频繁发生时,考虑使用其他容器如list

2. list:双向链表

list是一个双向链表,每个元素都有指向前一个和后一个元素的指针。它支持快速的插入和删除操作,尤其是在链表中间,但随机访问效率较低。

常见问题与避免策略:

  • 随机访问:由于list不支持随机访问迭代器,因此应避免使用基于索引的操作,改用迭代器遍历或直接使用插入/删除接口。
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
std::list<int> lst;
lst.push_back(1); // 在末尾插入元素
auto it = lst.begin();
lst.insert(++it, 2); // 在第二个位置插入元素
  • 内存占用:相较于vectorlist每个节点额外存储了指针,因此在大量小对象存储时,内存占用较高。选择list前应考虑这一点。

3. deque:双端队列

deque(双端队列)结合了vector的随机访问能力和list的快速插入删除特性,特别是在两端。它在内部使用分块的连续内存,使得头部和尾部的插入删除操作都非常高效。

常见问题与避免策略:

  • 中间操作:虽然deque两端操作高效,但在中间插入和删除仍然需要线性时间。尽量利用其两端操作的优势。
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
std::deque<int> deq;
deq.push_front(1); // 在前端插入
deq.push_back(2); // 在后端插入
  • 内存模型理解:虽然deque提供了类似vector的随机访问能力,但其内部实现差异意味着某些操作(如直接访问特定偏移量的元素)可能不如vector直观或高效。

总结

选择合适的容器是优化C++程序性能的关键一环。vector适合于需要快速随机访问且元素数量相对稳定的情况;list在频繁插入删除的场景下表现更佳;而deque则在需要快速在两端进行操作的应用中大放异彩。理解每种容器的内部机制和优缺点,能帮助我们做出更合理的选择,从而提升代码的效率和可维护性。在实际应用中,还需根据具体需求权衡,适时使用reserve()、选择正确的插入删除策略,以及考虑内存和性能的综合影响,才能最大化STL容器的价值。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2024-06-22,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
[C++] vector对比list & deque的引出
vector与list都是STL中非常重要的序列式容器,由于两个容器的底层结构不同,导致其特性以及 应用场景不同,其主要不同如下:
DevKevin
2024/08/02
1840
[C++] vector对比list & deque的引出
STL vector list deque区别与实现
    向量 相当于一个数组     在内存中分配一块连续的内存空间进行存储。支持不指定vector大小的存储。STL内部实现时,首先分配一个非常大的内存空间预备进行存储,即capacituy()函数返回的大小,当超过此分配的空间时再整体重新放分配一块内存存储,这给人以vector可以不指定vector即一个连续内存的大小的感觉。通常此默认的内存分配能完成大部分情况下的存储。    优点:(1) 不指定一块内存大小的数组的连续存储,即可以像数组一样操作,但可以对此数组                   进行动态操作。通常体现在push_back() pop_back()             (2) 随机访问方便,即支持[ ]操作符和vector.at()             (3) 节省空间。    缺点:(1) 在内部进行插入删除操作效率低。             (2) 只能在vector的最后进行push和pop,不能在vector的头进行push和pop。             (3) 当动态添加的数据超过vector默认分配的大小时要进行整体的重新分配、拷贝与释放
阳光岛主
2019/02/19
8630
移情别恋c++ ദ്ദി˶ー̀֊ー́ ) ——6.vector(无习题)
vector 是 C++ 标准模板库 (STL) 中的一种动态数组容器。它的底层实现是一个可以自动扩展的数组,支持随机访问和动态调整大小,是 C++ 中最常用的序列容器之一。vector 在插入、删除、遍历以及随机访问等方面有着优异的表现,尤其是在数据需要频繁随机访问且不会频繁在中间位置进行插入或删除操作的场景中表现非常出色。
hope kc
2024/10/17
2480
C++ 顺序容器基础知识总结
0.前言 本文简单地总结了STL的顺序容器的知识点。文中并不涉及具体的实现技巧,对于细节的东西也没有提及。一来不同的标准库有着不同的实现,二来关于具体实现《STL源码剖析》已经展示得全面细致。所以本文仅仅是对容器基础知识的归纳。至于容器提供的接口与使用实例,建议查取官方文档。文章难免有错漏,希望指出。 1.容器概论 容器,置物之所也。像桶可装水,碗可盛汤,C++的容器,可以存储对象。容器有多种,用来处理不同的元素操作诉求。按照元素存储到容器中以及访问方式的差异,容器分为顺序容器与关联容器。顺序容器也称为序列
Tencent JCoder
2018/07/02
1.4K0
3.1 C++ STL 双向队列容器
双向队列容器(Deque)是C++ STL中的一种数据结构,是一种双端队列,允许在容器的两端进行快速插入和删除操作,可以看作是一种动态数组的扩展,支持随机访问,同时提供了高效的在队列头尾插入和删除元素的操作。
王 瑞
2023/08/16
5240
顺序容器vector、list、deque的区别
顺序容器 三种容器均支持resieze()操作,重新划定容器大小,且此函数有重载。 vector vector和built-in数组类似,是一个在堆上建立的一维数组,它拥有一段连续的内存空间,并且起始地址不变,因此 它能非常好的支持随即存取,即[]操作符。vector因为存储在堆上,所以支持erase( ), resieze()(重新划分容器容量)等操作; vector不用担心越界当空间不够用的时候,系统会自动按照一定的比例(对capacity( )大小)进行扩充。在vector序列末尾添加(pus
Linux云计算网络
2018/01/10
1.1K0
深入探索 C++ STL: 高效双向链表 list 的使用与实践
C++ STL(Standard Template Library)的 list 容器是双向链表的实现,适合需要频繁插入和删除元素的场景。在这篇文章中,我将详细介绍 list 的特性、使用场景、常见的操作和使用示例,帮助读者全面掌握 list 的用法。本文分为以下几部分:
用户11286421
2024/10/20
2570
c++容器类_类的容器
首先,我们必须理解一下什么是容器,在C++ 中容器被定义为:在数据存储上,有一种对象类型,它可以持有其它对象或指向其它对像的指针,这种对象类型就叫做容器。很简单,容器就是保存其它对象的对象,当然这是一个朴素的理解,这种“对象”还包含了一系列处理“其它对象”的方法,因为这些方法在程序的设计上会经常被用到,所以容器也体现了一个好处,就是“容器类是一种对特定代码重用问题的良好的解决方案”。
全栈程序员站长
2022/11/04
9970
深入理解C++ STL中的 vector
前言: C++ Standard Template Library (STL) 是一个强大且灵活的库,提供了许多有用的数据结构和算法,其中vector 是最常用的容器之一。 vector是动态数组的封装,可以在运行时自动调整大小,提供了数组的效率以及更多的功能和灵活性。 在本文中,我们将深入讨论 vector的特性、使用方法、底层实现及其复杂性分析。
用户11286421
2024/10/16
5440
【C++】STL 容器 - deque 双端数组容器 ( deque 容器与 vector 容器区别 | 容器头部插入 / 删除元素 | 查询元素索引位置 | algorithm#find 函数 )
deque 是 " 双端数组容器 " , 全称 " 双端队列 " , 英文名称为 : " Double-Ended Queue " , 该容器可以在 首部 和 尾部 插入 和 删除 元素 ;
韩曙亮
2023/12/23
5420
【C++】STL 容器 - deque 双端数组容器 ( deque 容器与 vector 容器区别 | 容器头部插入 / 删除元素 | 查询元素索引位置 | algorithm#find 函数 )
C/C++工程师面试题(STL篇)
2. 关联式容器 元素是排序的;插入任何元素,都按相应的排序规则来确定其位置;在查找时具有非常好的性能;通常以平衡二叉树的方式实现,包含set、map。
SarPro
2024/03/16
3260
C/C++工程师面试题(STL篇)
【C++指南】解锁C++ STL:从入门到进阶的技术之旅
STL,即标准模板库(Standard Template Library) ,是 C++ 标准库的重要组成部分,是一个具有工业强度的、高效的 C++ 程序库。
倔强的石头_
2025/02/11
5400
C++ 容器全面剖析:掌握 STL 的奥秘,从入门到高效编程
C++ 标准模板库(STL)提供了一组功能强大的容器类,用于存储和操作数据集合。不同的容器具有独特的特性和应用场景,因此选择合适的容器对于程序的性能和代码的可读性至关重要。对于刚接触 C++ 的开发者来说,了解这些容器的基础知识以及它们的特点是迈向高效编程的重要一步。本文将详细介绍 C++ 常用的容器,包括序列容器(std::vector、std::array、std::list、std::deque)、关联容器(std::set、std::map)和无序容器(std::unordered_set、std::unordered_map),全面解析它们的特点、用法、适用场景及常见操作。
平凡之路.
2024/11/21
9880
【C++篇】深度剖析C++ STL:玩转 list 容器,解锁高效编程的秘密武器
C++ 标准模板库(STL)中的 list 容器是一个双向链表结构,它提供了高效的插入和删除操 作。与 vector 不同,list 中的元素不是连续存储的,因此可以在任何位置高效插入和删除元素,而无需移动其他元素。虽然它在随机访问方面不如 vector 高效,但在大量的插入和删除操作场景中具有不可替代的优势。
半截诗
2024/10/09
6530
移情别恋c++ ദ്ദി˶ー̀֊ー́ ) ——7.list(无习题)
list 是 C++ 标准模板库 (STL) 中的一种容器类型,采用双向链表的数据结构来存储数据。双向链表意味着每个节点包含一个数据元素和两个指针,分别指向前一个和后一个节点。list 适用于需要频繁进行插入和删除操作的场景,其效率比动态数组(如 vector)更高,但不支持随机访问。与 vector 使用连续内存存储不同,list 的节点在内存中并不连续存储。
hope kc
2024/10/17
2260
移情别恋c++ ദ്ദി˶ー̀֊ー́ ) ——7.list(无习题)
【深入探索 C++ STL 双端队列 deque】 —— 数据时空的双端虫洞,扭曲常规操作的效率边界
deque又叫双端队列(Double ended queue),头文件为<deque>,deque是 C++ 标准模板库(STL)中的一个容器类,它允许在两端进行高效的插入和删除操作。
换一颗红豆
2024/12/20
4590
【深入探索 C++ STL 双端队列 deque】 —— 数据时空的双端虫洞,扭曲常规操作的效率边界
c++ list, vector, map, set 区别与用法比较
List封装了链表,Vector封装了数组, list和vector得最主要的区别在于vector使用连续内存存储的,他支持[]运算符,而list是以链表形式实现的,不支持[]。 Vector对于随机访问的速度很快,但是对于插入尤其是在头部插入元素速度很慢,在尾部插入速度很快。List对于随机访问速度慢得多,因为可能要遍历整个链表才能做到,但是对于插入就快的多了,不需要拷贝和移动数据,只需要改变指针的指向就可以了。另外对于新添加的元素,Vector有一套算法,而List可以任意加入。 Map,Set属于标准
hbbliyong
2018/03/06
10.3K0
c++ list, vector, map, set 区别与用法比较
【C++】基础:STL标准库常用模块使用
C++标准模板库(Standard Template Library,STL)是C++中的一个重要组成部分,提供了丰富的容器、算法和函数模板,可以帮助开发人员快速实现通用的数据结构和算法。STL的设计目标是提供高效、可靠、易于使用的工具,以提高开发效率和代码可维护性。
DevFrank
2024/07/24
3140
C++ 中的容器类详解
C++中的容器类包括“顺序存储结构”和“关联存储结构”,前者包括vector,list,deque等;后者包括set,map,multiset,multimap等。若需要存储的元素数在编译器间就可以确定,可以使用数组来存储,否则,就需要用到容器类了。
全栈程序员站长
2022/09/30
9880
【C++】STL 容器总结 ( STL 各容器特点 | STL 个容器使用场景 | 单端数组容器 | 双端队列容器 | 双向链表容器 | 集合容器 | 多重集合容器 | 映射容器 | 多重映射容器 )
std::map 映射容器 与 std::set 集合容器 的区别是 map 容器存储的是 键值对 元素 , 是 pair 对象 , set 容器 存储的是 单纯的 键 单个元素 ;
韩曙亮
2024/01/05
5.6K0
推荐阅读
相关推荐
[C++] vector对比list & deque的引出
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档