vector如何判断应该扩容?

std::vector 的扩容机制是 C++ 容器性能优化的一个核心点。它的判断标准、行为特征和实现细节如下所示:


✅ 一、vector 的核心结构

std::vector 内部维护三个指针:

begin   -> 指向数据起始位置
end     -> 指向当前已使用的元素末尾(size)
capacity_end -> 指向当前分配的内存末尾(capacity)

如果你继续插入元素导致 end == capacity_end,即当前内存空间不够,就会触发扩容


✅ 二、什么时候触发扩容?

扩容条件:

size() >= capacity() 时,再插入元素,就触发扩容

也就是说:

vector.push_back(x);

如果此时元素个数 == 容量,就会 重新分配更大的内存空间 + 拷贝旧数据过去


✅ 三、扩容策略(增长规律)

不同编译器略有不同,但通常是:

新容量 = 当前容量 * 1.5 ~ 2

例如:

  • 初始容量为 0;
  • 插入第一个元素后,可能扩为 1;
  • 再插入一个元素,扩为 2;
  • 再插入一个,扩为 4;
  • 然后扩为 8、16、32…(指数增长)

这是为了避免频繁 realloc(拷贝/移动),提高效率。


✅ 四、如何手动控制扩容

1. reserve(n):预留空间但不改变 size

std::vector<int> vec;
vec.reserve(1000);  // 分配容量至少为 1000,避免中途多次扩容

2. resize(n):修改 size(实际元素个数)

vec.resize(100);  // 改变 vector 的 size,会初始化新元素

✅ 五、扩容的代价与注意事项

  • 重新分配内存(新的更大的空间);
  • 拷贝或移动旧元素到新空间;
  • 旧空间释放;
  • 所以 vector 的地址在扩容后是可能变化的,原先的指针/引用会失效

🔴 注意:不要在 vector 扩容后继续使用原先的指针或引用!


✅ 六、示例代码演示

#include <iostream>
#include <vector>int main() {std::vector<int> v;std::cout << "初始 capacity: " << v.capacity() << "\n";for (int i = 0; i < 20; ++i) {v.push_back(i);std::cout << "插入 " << i << ", size: " << v.size() << ", capacity: " << v.capacity() << "\n";}return 0;
}

📌 输出中你将看到:每隔几次 push_backcapacity 就倍增一次。


✅ 七、总结

项目vector 行为说明
扩容时机size >= capacity
扩容代价重新分配内存 + 拷贝/移动旧元素
扩容策略指数增长(一般为 1.5 或 2 倍)
控制扩容reserve(n) 提前分配空间避免多次扩容
注意事项扩容后地址可能变化,旧引用/指针可能失效

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/92771.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/92771.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ICMP考点

在网络工程师、运维工程师、安全工程师等岗位的面试中&#xff0c;​​ICMP&#xff08;Internet Control Message Protocol&#xff0c;互联网控制报文协议&#xff09;​​ 是高频必考知识点。ICMP作为IP协议的“辅助协议”&#xff0c;虽然不直接传输用户数据&#xff0c;但…

服务器带宽具体是指什么意思?

企业在选择服务器租用或托管服务时&#xff0c;需要根据自身的业务情况来选择合适的服务器带宽&#xff0c;以便于能够让其业务持续稳定的运行工作&#xff0c;做到及时响应用户的访问请求&#xff0c;但是很多用户对于带宽一词没有过多的概念&#xff0c;本文就来探讨一下服务…

CANape之ASAP2 Studio介绍

提到ECU的测量标定工具&#xff0c;很多小伙伴第一个想到的就是CANape。但其实&#xff0c;除了强大的测量标定功能之外&#xff0c;CANape还有很多其他功能。例如&#xff0c;CANape中集成的小工具——ASAP2 Studio&#xff0c;其支持对A2L文件&#xff08;由ASAM组织所定义&a…

【debug日记】MONAI SwinUNETR 目标检测项目调试总结(AI自动总结)

MONAI SwinUNETR 目标检测项目调试总结 日期: 2025年7月25日 项目: 使用 MONAI&#xff0c;以预训练的 SwinUNETR 为骨干网络&#xff0c;微调 RetinaNet 进行3D肺结节检测。 本文档旨在记录在项目配置、数据处理和模型训练过程中遇到的一系列问题及其解决方案&#xff0c;作为…

AI同传领域,字节跳动与科大讯飞激战进行时

在AI同声传译市场&#xff0c;行业巨头科大讯飞长期占据主导地位&#xff0c;但新晋玩家字节跳动正以迅猛姿态发起挑战。7月24日&#xff0c;字节旗下火山引擎正式发布豆包同声传译模型 Seed LiveInterpret 2.0&#xff0c;主打“人类级延迟”和“0样本声音复刻”&#xff0c;试…

[C++]string::substr

string substr (size_t pos 0, size_t len npos) const;substr() 主要功能是复制&#xff08;截取更准确&#xff09;子字符串&#xff0c;要求从指定位置 pos 开始&#xff0c;并具有指定的长度 len 。如果没有指定长度或者超出了源字符串的长度&#xff0c;则子字符串将延续…

KNN算法:从原理到实战全解析

一 算法介绍 K近邻&#xff08;K-Nearest Neighbors, KNN&#xff09;是一种基于实例的监督学习算法&#xff0c;适用于分类和回归任务。其核心思想是通过计算待预测样本与训练集中样本的距离&#xff0c;选取距离最近的K个邻居&#xff0c;根据这些邻居的标签进行投票&#xf…

医疗器械:DFEMA和PFEMA

在医疗器械行业&#xff0c;DFMEA&#xff08;Design FMEA&#xff0c;设计失效模式及影响分析&#xff09;和 PFMEA&#xff08;Process FMEA&#xff0c;过程失效模式及影响分析&#xff09;是核心的风险管理工具&#xff0c;旨在通过系统性识别潜在风险、分析影响并采取预防…

Qt 与 SQLite 嵌入式数据库开发

Qt 与 SQLite 的结合是开发轻量级、跨平台嵌入式数据库应用的理想选择。SQLite 作为一种零配置、文件型数据库&#xff0c;无需独立的服务器进程&#xff0c;非常适合集成到 Qt 应用中。本文将深入探讨 Qt 与 SQLite 的嵌入式数据库开发&#xff0c;包括基础操作、高级特性、性…

Oracle OMF 非OMF 文件 转化 不需要重建 file#.incarnation#

不需要重建就要重启&#xff0c; alter database datafile move 就可以在线 file#.incarnation# 是 incarnation 不是dbid Goal How to convert non OMF files to OMF files with ASM storage Datafiles are not deleted at dropping tablespace if files are non-OMF and …

大型微服务项目:听书——11 Redisson分布式布隆过滤器+Redisson分布式锁改造专辑详情接口

11 Redisson分布式布隆过滤器Redisson分布式锁改造专辑详情接口 11.1 缓存穿透解决方案&布隆过滤器 缓存穿透解决方案&#xff1a; 布隆过滤器&#xff1a; 布隆过滤器的使用&#xff1a; 11.2 远程调用查询所有的专辑id集合 修改&#xff1a; /*** 查询所有的专辑…

STM32与ADS1220实现多通道数据采集的完整分析和源程序

以下是基于STM32与ADS1220实现多通道数据采集的完整分析和源程序,结合硬件设计、通信协议及软件优化,提供高精度采集解决方案: 一、系统设计关键要点 ADS1220特性 24位高精度ΔΣ ADC,支持4路单端或2路差分输入 集成PGA(增益1~128)、基准电压和可编程电流源 多通道限制:…

百特搭AI低代码平台助力企业国际化业务敏捷拓展

在全球化浪潮下&#xff0c;企业扬帆出海或服务全球客户已成为重要战略。然而&#xff0c;开拓国际市场面临多重挑战&#xff1a;语言文化差异显著、本地化需求复杂多变、智能化应用需求激增、各国IT基础设施与合规要求各异。企业亟需一个能够快速响应、灵活适应&#xff0c;并…

epoll_event数据结构及使用案例详解

epoll_event 数据结构详解 在 Linux 的 I/O 多路复用机制 epoll 中&#xff0c;epoll_event 是关键的数据结构&#xff0c;用于描述文件描述符&#xff08;fd&#xff09;上的事件和关联数据。其定义在头文件 <sys/epoll.h> 中&#xff1a; struct epoll_event {uint32_t…

C++11STL容器map和set简单介绍

一、引言map和set底层结构比较复杂&#xff0c;我认为我们先谈基本介绍再谈C11&#xff0c;最后再谈map和set底层以及map和set封装。二、简单介绍一下map和setmap和set底层都是红黑树&#xff0c;是二叉搜索树的一种&#xff0c;查找非常快。不像数组、链表一样一个一个对比&am…

Java线程基础面试复习笔记

1. 线程与进程的区别进程是正在运行程序的实例&#xff0c;线程是进程中的执行单元。主要区别&#xff1a; 内存空间&#xff1a;不同进程使用不同的内存空间&#xff0c;同一进程下的线程共享内存空间资源开销&#xff1a;线程更轻量&#xff0c;线程上下文切换成本比进程上下…

面试题(技术面+hr面)

面试技术面HR面后端HR面常见问题*稳定性&#xff0c;上进心&#xff0c;目标感&#xff0c;抗压能力&#xff0c;学习能力*回答问题时注意体现上面五点&#xff0c;即使瞎扯也尽量往上靠。面经项目相关介绍一下你收获最大的一个项目你们团队有多少人&#xff0c;怎么分工的开发…

本地部署Dify教程

克隆 Dify 代码仓库克隆 Dify 源代码至本地。git clone hts://github.com/langgenius/dify.git启动 Dify进入 Dify 源代码的 docker 目录&#xff0c;执行一键启动命令:cd dify/docker #切换到指定目录 cp .env.example .env #修改文件名 docker compose up -d #启动

Android Kotlin 协程全面指南

协程是 Kotlin 提供的一套简化异步编程的轻量级线程操作框架&#xff0c;特别适合 Android 开发中的异步任务处理。以下是 Android 开发中需要掌握的协程核心知识点&#xff1a;1. 协程基础概念1.1 协程是什么轻量级线程&#xff1a;比线程更高效&#xff0c;可以在单个线程中运…

【Linux】进程切换与优先级

前言&#xff1a; 上文我们讲到了操作系统与Linux中进程的状态【Linux】进程状态-CSDN博客 本文我们来讲进程的优先级、以及进程的切换 进程优先级 什么是优先级&#xff1f; CPU中资源是有限的&#xff0c;而进程的数量一定是远大于CPU资源的&#xff0c;所以优先级是进程得…