C++之vector和list辨析
std::vector 和 std::list 是 C++ 标准库中两种常用的容器,它们都用于存储和管理元素集合,但在底层实现和性能特性上有显著的区别。
1. 底层实现
std::vector:- 基于动态数组实现。
- 元素在内存中是连续存储的。
- 支持随机访问(通过下标访问元素)。
- 当容量不足时,会重新分配更大的内存块,并将所有元素复制到新内存中。
std::list:- 基于双向链表实现。
- 元素在内存中是非连续存储的,每个元素包含指向前后元素的指针。
- 不支持随机访问,只能通过迭代器顺序访问。
- 插入和删除操作不会导致内存重新分配。
2. 性能特性
| 操作 | std::vector | std::list |
|---|---|---|
| 随机访问 | O(1)(通过下标直接访问) | O(n)(需要遍历链表) |
| 尾部插入/删除 | O(1)(如果不需要扩容) | O(1) |
| 头部插入/删除 | O(n)(需要移动所有元素) | O(1) |
| 中间插入/删除 | O(n)(需要移动部分元素) | O(1)(找到位置后直接插入/删除) |
| 内存占用 | 较小(仅存储元素,无额外开销) | 较大(每个元素需要额外存储两个指针) |
| 缓存友好性 | 高(元素连续存储,缓存命中率高) | 低(元素非连续存储,缓存命中率低) |
3. 适用场景
std::vector:- 需要频繁随机访问元素的场景。
- 元素数量变化不大,或者主要在尾部插入/删除元素的场景。
- 对缓存性能要求高的场景。
std::list:- 需要频繁在任意位置插入/删除元素的场景。
- 不需要随机访问元素的场景。
- 元素数量变化较大的场景。
4. 实例
#include <iostream>
#include <vector>
#include <list>int main() {// std::vector 示例std::vector<int> vec = {1, 2, 3};vec.push_back(4); // 尾部插入vec.insert(vec.begin() + 1, 5); // 中间插入std::cout << "Vector: ";for (int v : vec) std::cout << v << " "; // 随机访问std::cout << std::endl;// std::list 示例std::list<int> lst = {1, 2, 3};lst.push_back(4); // 尾部插入lst.insert(std::next(lst.begin()), 5); // 中间插入std::cout << "List: ";for (int l : lst) std::cout << l << " "; // 顺序访问std::cout << std::endl;return 0;
}
相关文章:
C++之vector和list辨析
std::vector 和 std::list 是 C 标准库中两种常用的容器,它们都用于存储和管理元素集合,但在底层实现和性能特性上有显著的区别。 1. 底层实现 std::vector: 基于动态数组实现。元素在内存中是连续存储的。支持随机访问(通过下标访问元素&a…...
冯诺依曼体系结构 ──── linux第8课
目录 冯诺依曼体系结构 关于冯诺依曼,必须强调几点: 冯诺依曼体系结构 我们常见的计算机,如笔记本。我们不常见的计算机,如服务器,大部分都遵守冯诺依曼体系 输入单元:包括键盘, 鼠标,网卡,扫…...
EX_25/2/22
找到第一天mystring练习,实现以下功能 mystring str "hello" mystring ptr "world" str str ptr; str ptr str[0] H #include <iostream> #include <cstring> #include <cstdlib> #include <unistd.h> #in…...
rust安装教程以及git连接到远程仓库
1.官方网站下载rustup-init程序 链接: rust-lang 从这里可以获取到rust的下载程序,这个下载程序会帮助你下载visual-studio的安装包从而获取相关的编译环境。 tips:无需再下载visual_studio 2确认安装所需要的框架,SKD工具 安装完毕之后可以检查一下 rustc --ve…...
Kafka系列之:记录一次源头数据库刷数据,造成数据丢失的原因
Kafka系列之:记录一次源头数据库刷数据,造成数据丢失的原因 一、背景二、查看topic日志信息三、结论四、解决方法一、背景 源头数据库在很短的时间内刷了大量的数据,部分数据在hdfs丢失了 理论上debezium数据采集不会丢失,就需要排查数据链路某个节点是否有数据丢失。 数据…...
VC++零基础入门之系列教程 【附录E MFC快速参考指南】
附录E MFC快速参考指南 E.1 创建窗口 使用M F C CWnd wnd; W n d . C r e a t e E x ( E xSt y l e , C l a s s N a m e , Wi n d o w N a m e , S t y l e , x , y, Wi d t h , H e i g h t , P a r e n t , M e n u , P a r a m ) ; 使用A P I HWND hwnd=::CreateWi n d …...
在CentOS 7下部署NFS的详细教程
在CentOS 7下部署NFS的详细教程 NFS(Network File System)是一种分布式文件系统协议,允许用户在网络中的不同主机之间共享文件和目录。NFS广泛应用于Linux和Unix系统中,特别适合在集群环境中共享存储资源。本文将详细介绍如何在C…...
LabVIEW C编译支持工具库CCompileSupp.llb
路径:C:\Program Files (x86)\National Instruments\LabVIEW 2019\vi.lib\Platform\CCompileSupp.llb 1. 工具库概述 定位:LabVIEW内置的C语言编译支持工具库,用于处理LabVIEW与C/C代码的混合编程接口,涵盖编译器配置、代码生成…...
【含文档+PPT+源码】基于微信小程序的农产品自主供销商城系统
项目介绍 本课程演示的是一款基于微信小程序的农产品自主供销商城系统,主要针对计算机相关专业的正在做毕设的学生与需要项目实战练习的 Java 学习者。 1.包含:项目源码、项目文档、数据库脚本、软件工具等所有资料 2.带你从零开始部署运行本套系统 3…...
MongoDB私人学习笔记
俗话说“好记性不如烂笔头”,编程的海洋如此的浩大,养成做笔记的习惯是成功的一步! 此笔记主要是ZooKeeper3.4.9版本的笔记,并且笔记都是博主自己一字一字编写和记录,有错误的地方欢迎大家指正。 一、基础知识…...
C++---了解STL
上节学习了模板,那么就得谈到C的标准模板库STL。 C98:以模板方式重写了C标准库,引入了STL(标准模板库)。 1.概念 STL(Standard template Libarary)标准模板库:是C标准库的重要组成部分,不仅是一个可复用的组件库&am…...
智能自动化新纪元:AI与UiPath RPA的协同应用场景与技术实践
智能自动化新纪元:AI与UiPath RPA的协同应用场景与技术实践 引言 在数字化转型的浪潮中,企业对于自动化技术的需求已从简单的任务执行转向更复杂的智能决策。传统RPA(Robotic Process Automation)通过模拟人类操作处理重复性任务…...
2025年2月科技热点深度解析:AI竞赛、量子突破与开源革命
引言 2025年的科技领域持续呈现爆发式增长,AI大模型竞争白热化、量子计算商业化加速、开源工具生态繁荣成为本月最受关注的议题。本文结合最新行业动态,从技术突破、商业布局到开发者生态,全面解析当前科技热点,为读者提供深度洞…...
计算机网络————(三)
前文二 前文一 Websocket协议 是一种存在TCP协议之上的协议 当客户端需要了解服务器是否更新就需要不断给客户端发送请求询问是否更新,这行会造成服务端压力很大 而Websocket相当于服务器一旦更新了就会给客户端发送消息表明自己更新了,类似客户端订阅…...
请谈谈 React 中的状态管理,如何使用 Context API 和 Redux 进行状态管理?
一、Context API 深度应用 1. 核心实现原理 通过createContext创建上下文对象,使用Provider组件包裹需要共享状态的组件树,子组件通过useContext Hook或Consumer组件消费数据。 代码示例(主题切换场景): // 创建上…...
【考研】复试相关上机题目
文章目录 22机试回忆版1、判断燃气费描述输入格式输出格式输入样例输出样例 C o d e Code Code 2、统计闰年数量描述输入格式输出格式输入样例输出样例 C o d e Code Code 3、打印图形描述输入格式输出格式 C o d e Code Code 4、密文数据描述输入格式输出格式输入样例输出样例…...
利用机器学习实现实时交易欺诈检测
以下是一个基于Python的银行反欺诈AI应用示例代码,演示如何利用机器学习实现实时交易欺诈检测。该示例使用LightGBM算法训练模型,并通过Flask框架构建实时检测API: python import pandas as pd from sklearn.model_selection import train_test_split from sklearn.preproc…...
Modelfile配置说明
参数说明翻译 参数描述值类型示例用法mirostat启用Mirostat采样以控制困惑度。(默认:0,0禁用,1Mirostat,2Mirostat 2.0)intmirostat 0mirostat_eta影响算法对生成文本反馈的响应速度。较低的学习率将导致调…...
labview实现有符号位16进制转二进制补码转真值
今天在用一个采集模块时,发现读出寄存器的数据是不同的,它有两种范围,一个时十六进制整型,一种是有符号位十六进制,对应的量程和范围也是不同的,针对之前读取温度没有出现负数的情况,应该是转成…...
浏览器深度解析:打造极速、安全、个性化的上网新体验
在数字化时代,浏览器作为我们获取信息、娱乐休闲的重要工具,其性能与功能直接影响着我们的上网体验。今天,我将为大家介绍一款备受好评的浏览器——Yandex浏览器,并深入解析其独特功能与优势,帮助大家更好地了解并选择这款上网神器。 一、知名公司背书,开源项目融合 Yan…...
如何为物化视图创建索引_提升基于物化视图的聚合查询性能
能,但取决于数据库系统;PostgreSQL、Oracle支持直接建索引,MySQL需模拟实现;索引生效需满足数据非空、统计信息更新、查询写法合规等条件。物化视图上能直接建索引吗?能,但取决于数据库系统。postgresql 从…...
5分钟精通百度网盘提取码智能获取:baidupankey完全使用指南
5分钟精通百度网盘提取码智能获取:baidupankey完全使用指南 【免费下载链接】baidupankey 项目地址: https://gitcode.com/gh_mirrors/ba/baidupankey 还在为百度网盘分享链接的提取码而烦恼吗?每次遇到需要密码的资源都要四处搜索,浪…...
2026年全国青少年信息素养大赛算法应用主题赛(C++赛项模拟训练5:文末附答案)
2026年全国青少年信息素养大赛算法应用主题赛(C赛项模拟训练5:文末附答案) 5道单选5道多选4道编程 一、单选题 在记录丝绸交易的金额时,需要保留两位小数。下列输出语句能够正确输出变量 money(浮点数)并保…...
如何快速解密微信聊天记录:WechatDecrypt工具完全指南
如何快速解密微信聊天记录:WechatDecrypt工具完全指南 【免费下载链接】WechatDecrypt 微信消息解密工具 项目地址: https://gitcode.com/gh_mirrors/we/WechatDecrypt 微信聊天记录承载着我们珍贵的回忆和重要的工作沟通,但当更换设备或需要数据…...
【高届数土木会议】第十届土木建筑与结构工程国际学术会议(I3CSE 2026)
第十届土木建筑与结构工程国际学术会议(I3CSE 2026) 2026 10th International Conference on Civil Construction and Structural Engineering 广东省岩土力学与工程学会、华南农业大学主办 高届数EI会议,见刊检索稳定 会议官网: 第十届土木建筑与结构工程国际学术会议(…...
科大讯飞回应网传员工中 1500 大奖
前情:《网传“讯飞外包中奖 1500 万后闪电离职”。网友:彩票又滞销了》①据红星新闻称,在官方彩票开奖数据中,合肥近期无 1500 万元级别大奖记录。4 月11 日安徽出了 1 注 1000 万体彩大奖,是在宿州,而且和…...
别再乱选颜色了!用Seaborn的color_palette()函数,5分钟搞定数据可视化配色
别再乱选颜色了!用Seaborn的color_palette()函数,5分钟搞定数据可视化配色 上周帮同事Review代码时,看到他用Matplotlib画了这样一张柱状图:12个分类变量用了完全随机的RGB颜色,荧光粉配亮绿,还加了3D阴影效…...
Pixel Script Temple 目标检测辅助标注:基于YOLOv5预测结果生成可视化报告
Pixel Script Temple 目标检测辅助标注:基于YOLOv5预测结果生成可视化报告 1. 引言:当YOLOv5遇上可视化报告 在计算机视觉项目中,我们常常遇到这样的困境:YOLOv5模型跑完了,检测结果也出来了,但面对一堆枯…...
Advanced Computing 正式启航,聚焦计算机科学全领域,现已开放投稿!
Advanced Computing 是一本聚焦计算机科学全领域的开放获取期刊,从理论基础、软件工程到人工智能、计算机视觉及新兴技术等方向,都属于其发表范畴。内容范围包括但不限于以下领域: 理论计算机科学与算法:包括算法设计与分析、计算…...
01-秒杀系统设计详解
秒杀系统设计详解 一、知识概述 秒杀系统是电商领域最具挑战性的高并发场景之一,典型特征是瞬时高并发、库存有限、时间敏感。一个成功的秒杀系统需要在极短时间内处理海量请求,同时保证数据一致性和用户体验。 核心挑战: 流量突增:平时QPS可能只有几十,秒杀开始瞬间可…...
