【Example】C++ Vector 内存预分配的良好习惯
为什么要对 Vector 进行内存预分配?
1,Vector 本身是一个内存只会增长不会减小的容器。
2,Vector 存在 size 和 capacity 两种计数,size 即元素个数,capacity 则是容量即 vector 在内存当中的大小,理论上始终 capacity >= size。
3,Vector 的 push_back 函数逻辑是,当 capacity 不够的时候,去申请一块新内存,将原有数据拷贝到新内存再释放旧内存,中间有一个申请、拷贝、释放的操作。
4,最根本目的是加强 Vector 写入时的性能。
什么样的 Vector 需要进行内存预分配?
存储的对象内存消耗大且数量多的Vector。
如果一个Vector就存了几百条int,则没必要去折腾。
#include <iostream> #include <vector> using std::vector; // 随便创建一个结构体 typedef struct Point { int x; int y; int val; // 顺带演示统一初始化 (现代C++) Point(int x, int y, int value) : x(x), y(y), val(value) {}; }; int main() { // 定义两个 vector vector<Point> pointsT1; vector<Point> pointsT2; for (size_t i = 0; i < 45000; i++) { pointsT1.push_back(Point(i, i, -99999)); } // 执行耗时 8.3213 毫秒
pointsT2.reserve(45000); for (size_t i = 0; i < 45000; i++) { pointsT2.push_back(Point(i, i, -99999)); } // 执行耗时 3.7997 毫秒 return EXIT_SUCCESS; }
=================================
由此可见,进行了预分配内存操作的 Vector 存入时间缩短了 65%。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具