代码随想录八股训练营第三十四天| C++
前言
一、vector和list的区别?
1.1.存储方式:
1.2.随机访问:
1.3.插入和删除操作:
1.4.内存使用:
1.5.容量和大小:
1.6.迭代器类型:
1.7.用途:
二、vector 底层原理和扩容过程?
2.1.底层原理:
2.2. 扩容过程:
总结
前言
在C++ 编程中,选择合适的数据结构对于优化程序性能和资源使用至关重要。标准模板库(STL)提供了多种容器,其中 vector 和 list 是两种常用的序列容器,它们各自具有独特的特性和适用场景。了解这些容器的内部机制和性能特点,可以帮助开发者根据具体需求做出更合理的选择。
一、vector和list的区别?
在 C++ 中,vector 和 list 都是标准模板库(STL)中的序列容器,用于存储元素集合。它们的主要区别如下:
1.1.存储方式:
vector是一个动态数组,它在内存中连续存储元素。这意味着元素在内存中是紧密排列的,类似于数组。list是一个双向链表,每个元素由一个节点表示,节点之间通过指针连接。这种结构使得list在插入和删除操作中更加灵活。
1.2.随机访问:
vector支持随机访问,即可以通过下标直接访问任何元素,访问时间复杂度为 O(1)。list不支持随机访问,访问特定元素需要从头或尾开始遍历,直到到达所需元素,访问时间复杂度为 O(n)。
1.3.插入和删除操作:
vector在插入和删除元素时,如果需要移动内存中的元素来保持连续性,可能会有较高的开销。特别是当容器大小需要增长时,可能需要分配新的内存并复制现有元素。list在插入和删除元素时,只需要调整节点之间的指针,不需要移动其他元素,因此在这些操作上通常比vector更高效。
1.4.内存使用:
vector通常在内存使用上更紧凑,因为它是一个连续的存储块。list由于每个元素都需要额外的空间来存储指针(至少两个指针,指向前一个和后一个元素),因此内存使用上不如vector紧凑。
1.5.容量和大小:
vector维护了size(当前元素数量)和capacity(容器能够容纳的最大元素数量)两个概念。当size达到capacity时,vector会进行扩容操作。list没有capacity的概念,它可以根据需要动态增长,不需要像vector那样进行扩容。
1.6.迭代器类型:
vector的迭代器支持随机访问,可以进行复杂的迭代操作,如std::sort。list的迭代器是双向迭代器,只能进行顺序访问,不支持随机访问。
1.7.用途:
vector适合于需要频繁随机访问元素的场景,如数值计算、游戏开发中的动态数组等。list适合于需要频繁插入和删除元素的场景,如实现算法中的链表结构、维护一个有序的元素集合等。
二、vector 底层原理和扩容过程?
在 C++ 中,std::vector 是一种序列容器,它封装了动态大小的数组。以下是 std::vector 的一些底层原理和扩容过程:
2.1.底层原理:
-
动态数组:
vector内部使用一个连续的内存块来存储元素,这个内存块的大小可以通过capacity()方法获取。 -
迭代器:
vector提供了随机访问迭代器,这意味着你可以像使用普通数组一样通过下标访问元素。 -
内存管理:
vector负责管理其内部数组的内存分配和释放。当元素被添加到vector时,它会检查当前的容量是否足够。如果不够,它会进行扩容。 -
构造和析构:
vector会为每个元素调用构造函数,当元素被移除或vector被销毁时,会调用析构函数。
2.2. 扩容过程:
-
容量检查:当你尝试添加元素到
vector时,如果当前vector的size等于capacity,vector需要扩容。 -
分配新内存:
vector会分配一个新的内存块,通常这个新内存块的大小是当前容量的两倍,或者按照某个特定的增长策略。 -
复制元素:
vector会使用拷贝或移动构造函数将现有元素从旧内存块复制到新内存块。 -
释放旧内存:一旦所有元素都被成功复制到新内存块,
vector会释放旧内存块。 -
更新迭代器和指针:由于内存块的地址发生了变化,所有指向旧内存块的迭代器和指针都会失效。因此,任何在扩容前获取的迭代器都需要在扩容后重新获取。
-
性能考虑:扩容是一个昂贵的操作,因为它涉及到分配新内存、复制元素和释放旧内存。因此,频繁的扩容可能会导致性能问题。
-
手动控制:可以通过调用
reserve()方法来手动设置vector的容量,这样可以减少在添加元素时进行的扩容次数。 -
缩减容量:如果不再需要
vector的额外容量,可以调用shrink_to_fit()方法来请求减少vector的内存使用,但这不保证容量会减少,因为标准库实现可能会忽略这个请求。
总结
vector 和 list 作为 C++ STL 中的两种序列容器,它们在数据存储、访问方式、操作效率等方面有着显著的差异。vector 提供了类似动态数组的功能,支持快速的随机访问,适合于需要频繁访问元素的场景。而 list 实现了双向链表,提供了高效的插入和删除操作,尤其适合于元素频繁变动的情况。开发者应根据实际应用的需求,权衡两者的优缺点,选择最合适的容器类型,以实现最优的性能和资源利用。
相关文章:
代码随想录八股训练营第三十四天| C++
前言 一、vector和list的区别? 1.1.存储方式: 1.2.随机访问: 1.3.插入和删除操作: 1.4.内存使用: 1.5.容量和大小: 1.6.迭代器类型: 1.7.用途: 二、vector 底层原理和扩容过…...
《深入理解 Java 中的 this 关键字》
目录 一、this关键字的基本理解 二、this调用属性和方法 (一)一般情况 (二)特殊情况 三、this调用构造器 四、案例分析 (一)Account类 (二)Customer类 (三&…...
python文件自动分类(5)
完成了文件自动分类的操作后,我们一起来复习下: 首先,获取文件夹中所有文件名称,用 os.path.join() 函数拼接出要移动到的目标地址。然后,使用 os.path.exists() 函数判断目标文件夹是否存在,不存在用 os.m…...
【Unity-Lua】音乐播放器循环滚动播放音乐名
前言:Unity中UI节点 图1 如上所示,一开始本来是打算用ScrollView做的,觉得直接计算对应的文本位置就行,所以没用ScrollRect来做,可以忽略Scroll,Viewport这些名字。如下图:需要在一个背景Image…...
宏碁扩展Swift系列,推出四款全新AI笔记本电脑
Acer正在扩展其Swift笔记本产品线,推出四款新型号,每款都内置了AI功能。这些笔记本提供诸如Microsoft Copilot、Acer用户感应技术、Windows Studio效应、PurifiedVoice 2.0和PurifiedView等功能。其他功能还包括Wi-Fi 7和Bluetooth 5.4连接。 我们先来看…...
科研绘图系列:R语言差异基因四分图(Quad plot)
文章目录 介绍加载R包导入数据数据预处理画图参考介绍 四分图(Quad plot)是一种数据可视化技术,通常用于展示四个变量之间的关系。它由四个子图组成,每个子图都显示两个变量之间的关系。四分图的布局通常是2x2的网格,每个格子代表一个变量对的散点图。 在四分图中,通常…...
文字或图案点选坐标点返回
最近看到这篇文章中讲到极验图片验证码破解方案 https://blog.geetest.com/article/65aaaa944edc5ec343ba9f52efef0cdc 其中核心解决步骤如下,作者还贴心的贴出了CNN代码,真是用心良极: step 3:批量下载存储验证图片,…...
硬盘数据恢复软件TOP4榜单出炉,选对方法竟然如此重要
这年头,信息多得不得了,数据对我们来说太重要了。但是,不管是咱们自己还是公司,都可能碰上丢数据的倒霉事,特别是不小心把硬盘里的东西删了。数据一丢,不光可能亏钱,工作和生活也可能受影响。好…...
给自己复盘用的随想录笔记-栈与队列
用栈实现队列 难在出去 232. 用栈实现队列 - 力扣(LeetCode) class MyQueue {private Stack<Integer> A;private Stack<Integer> B;public MyQueue() {Anew Stack<>();Bnew Stack<>();}public void push(int x) {A.push(x);}pu…...
微信小程序跳转到另一个微信小程序
引用:http://www.xmdeal.com/mobanjiaocheng/254.html 第一种方法: wx.navigateToMiniProgram 官方文档:https://developers.weixin.qq.com/miniprogram/dev/api/navigate/wx.navigateToMiniProgram.html wx.navigateToMiniProgram({appId…...
【知识图谱】4、LLM大模型结合neo4j图数据库实现AI问答的功能
昨天写了一篇文章,使用fastapi直接操作neo4j图数据库插入数据的例子, 本文实现LLM大模型结合neo4j图数据库实现AI问答功能。 废话不多说,先上代码 import gradio as gr from fastapi import FastAPI, HTTPException, Request from pydantic…...
《信息技术 云计算 边缘云通用技术要求》国家标准发布,九州未来参编
日前,2024年第17号国家标准公告发布,由全国信标委云计算标准工作组组织制定、九州未来作为行业专家单位参编的《信息技术 云计算 边缘云通用技术要求》国家标准正式获批发布。 边缘云作为云计算技术的有效补充和拓展,能够实现将云计算能力拓展…...
NTFS硬盘支持工具Paragon NTFS for Mac 15.4.44 中文破解版
Paragon NTFS for Mac 15.4.44 中文破解版是一个底层的文件系统驱动程序,专门开发用来弥合Windows和Mac OS X之间的不兼容性,通过在Mac OS X系统下提供对任何版本的NTFS文件系统完全的读写访问服务来弥合这种不兼容性。为您轻松解决Mac不能识别Windows NTFS文件难题…...
66-java 类型擦除
类型擦除是Java类型信息在运行时的一个特性,它发生在泛型类型被擦除成它们的原始类型后,以及在运行时,由于类型擦除,泛型信息不可用。 例如,以下两个泛型类型: List<String> list1 new ArrayList&…...
25考研人数预计下降?这一届考研有哪些新趋势?
2025年考研时间线: 2024年9月:公共课及各院校考试大纲公布; 2024年9月下旬:预报名; 2024年10月:正式报名; 2024年11月:线上/线下确认; 2024年12月中下旬:…...
比尔·盖茨对AI充满信心
The Verge与比尔盖茨进行了关于AI、错误信息和气候变化的对话。 比尔盖茨花费数十亿美元资助他认为将塑造未来的技术——从应对气候变化到消灭疾病。 盖茨在一部新的Netflix系列片《未来之路:比尔盖茨的境界》中深入探讨了这些话题。该系列于9月18日首播ÿ…...
Selenium 实现图片验证码识别
前言 在测试过程中,有的时候登录需要输入图片验证码。这时候使用Selenium进行自动化测试,怎么做图片验证码识别?本篇内容主要介绍使用Selenium、BufferedImage、Tesseract进行图片 验证码识别。 环境准备 jdk:1.8 tessdata&…...
基于云原生向量数据库 PieCloudVector 的 RAG 实践
近年来,人工智能生成内容(AIGC)已然成为最热门的话题之一。工业界出现了各种内容生成工具,能够跨多种模态产生多样化的内容。这些主流的模型能够取得卓越表现,归功于创新的算法、模型规模的大幅扩展,以及海…...
内存泄漏的影响
(1)内存泄漏是什么? 内存泄漏是指程序运行过程中分配的内存没有被正确释放,导致这部分内存无法再次使用,从而造成内存资源的浪费。内存泄漏可能会导致系统性能下降、程序崩溃或者消耗过多的系统资源;内存泄漏通常发生在动态分配的…...
shell变量扩展你知道多少?
1. shell变量扩展 我们知道,${var}的形式可以获取变量var的值,但其实还可以有更多花式玩法。其中~表示用户根目录其实属于 波浪线扩展,这比较常见,不展开介绍了。 下面的每种情况中,word 都要经过波浪线扩…...
从零到精通:全面掌握AI大模型的系统学习路径,大模型时代掌握未来,抢占AI风口!
本文介绍了人工智能领域的大型预训练模型——大模型,解释了其工作原理和应用场景,如自然语言处理、内容推荐、教育和辅助学习、医疗和健康护理等。文章还探讨了学习大模型的意义,包括技术趋势、就业市场、解决问题能力、创新能力等方面。此外…...
【.NET 9低代码开发终极指南】:20年微软生态专家亲授——零前端经验如何3天交付生产级业务应用?
第一章:.NET 9低代码开发全景认知与核心价值定位.NET 9 将低代码能力深度融入平台原生架构,不再依赖第三方插件或独立运行时,而是通过统一的组件模型、声明式 UI 编程范式与智能元数据驱动机制,实现“写少做多”的开发体验。其核心…...
MATLAB里画双移线总报错?手把手教你解决MPC轨迹跟踪仿真中的参考轨迹绘制难题
MATLAB双移线绘制报错全解析:从MPC轨迹跟踪到参考轨迹精准生成 引言:当MATLAB遇上双移线 在无人驾驶和车辆控制领域,双移线测试是评估车辆动态性能和控制器跟踪能力的黄金标准。作为MPC(模型预测控制)算法的学习者&…...
ES6——数组的扩展详解
数组的扩展详解1、Array.from()2、Array.of()3、数组实例的copyWithin()4、数组实例的find()和findIndex()5、数组实例的fill()6、数组实例的entries()、keys()和values()8、数组的空位9、数组推导1、Array.from() Array.from方法用于将两类对象转为真正的数组:类似…...
uniApp相机、存储、电话权限申请全攻略:告别频繁弹窗,提升用户体验
uniApp权限管理艺术:优雅实现相机、存储、电话权限的智能授权策略 在移动应用开发中,权限管理一直是开发者与用户之间的微妙博弈。过于频繁的权限请求会引发用户反感,而缺乏透明度的权限获取又可能导致应用商店审核失败。如何在uniApp框架下构…...
自动化测试面试中常见的问题
一、测试用例再执行点击元素时失败,导致整个测试用例失败。如何提高点击元素的成功率?解决办法:selenium是在点击元素时是通过元素定位的方式找到元素的,要提高点击的成功率,必须保证找到元素的定位方式准确。但是在自动化工程的…...
10.3处理流程设计-系统设计-人机界面设计
一、流程设计 00:00 1. 流程设计工具 00:25 1)程序流程图 00:32 基本概念: 用图框表示各种操作,独立于程序设计语言,直观清晰结构组成: 仅由顺序、选择和循环三种基本结构组合或嵌套而成应用场景: 可描述…...
3个强力步骤:百度网盘插件让macOS用户突破下载限速
3个强力步骤:百度网盘插件让macOS用户突破下载限速 【免费下载链接】BaiduNetdiskPlugin-macOS For macOS.百度网盘 破解SVIP、下载速度限制~ 项目地址: https://gitcode.com/gh_mirrors/ba/BaiduNetdiskPlugin-macOS 副标题:如何在不升级会员的情…...
Pretext:值得关注的文本排版引擎陨
一、语言特性:Java 26 与模式匹配进化 1.1 Java 26 语言级别支持 IDEA 2026.1 EAP 最引人注目的变化之一,就是新增 Java 26 语言级别支持。这意味着开发者可以提前体验和测试即将在 JDK 26 中正式发布的语言特性。 其中最重要的变化是对 JEP 530 的全面支…...
windows安装达梦数据库
在官网下载对应需要的安装包: https://www.dameng.com/download/index.html 下载后解压: 点击镜像开始安装: 这里没有key先不填直接下一步: 根据需要安装,这里默认全部安装: 指定安装目录地址࿱…...
