0

0

如何用C++实现动态扩容数组 std vector的底层原理剖析

P粉602998670

P粉602998670

发布时间:2025-07-28 10:13:01

|

952人浏览过

|

来源于php中文网

原创

std::vector自动扩展容量的原理是通过动态扩容机制实现。当调用push_back时,若当前size超过capacity,则触发扩容;通常采用2倍增长策略申请新的内存空间;将原有数据拷贝到新内存并释放旧内存;核心涉及capacity与size的区别、扩容策略、元素迁移三个关键点。手动实现需关注内存分配、数据迁移和容量更新逻辑,而实际vector还优化了内存管理、构造析构和移动语义等细节。

如何用C++实现动态扩容数组 std vector的底层原理剖析

在 C++ 中,std::vector 是一个非常常用的容器,它本质上就是一个动态扩容的数组。你可能用过 vector.push_back(),但有没有想过它是怎么自动扩展容量的?这篇文章就来聊聊它的底层原理,并演示如何手动实现一个简单的动态扩容数组。

如何用C++实现动态扩容数组 std vector的底层原理剖析

动态扩容数组的核心机制

std::vector 背后的核心机制其实并不复杂:使用堆内存管理一块连续的空间,当空间不足时,重新申请更大的内存,把旧数据复制过去,然后释放原来的内存。

如何用C++实现动态扩容数组 std vector的底层原理剖析

主要涉及以下几个关键点:

立即学习C++免费学习笔记(深入)”;

  • 容量(capacity)和大小(size)的区别size 表示当前有效元素个数,capacity 表示当前分配了多少内存。
  • 扩容策略:一般采用倍增方式,比如 2 倍增长,也有部分实现是 1.5 倍。
  • 拷贝或移动元素:扩容后需要把原来的数据迁移到新内存中。

如果你自己写一个类似 vector 的类,这几个概念必须搞清楚。

如何用C++实现动态扩容数组 std vector的底层原理剖析

手动实现一个简易动态扩容数组

下面是一个简化版的动态数组实现,用于理解 vector 的基本工作方式:

template
class MyVector {
private:
    T* data;
    size_t capacity_;
    size_t size_;

public:
    MyVector() : data(nullptr), capacity_(0), size_(0) {}

    ~MyVector() {
        delete[] data;
    }

    void push_back(const T& value) {
        if (size_ >= capacity_) {
            reserve(capacity_ == 0 ? 1 : capacity_ * 2);
        }
        data[size_++] = value;
    }

    void reserve(size_t new_cap) {
        if (new_cap <= capacity_) return;

        T* new_data = new T[new_cap];
        for (size_t i = 0; i < size_; ++i) {
            new_data[i] = data[i];
        }

        delete[] data;
        data = new_data;
        capacity_ = new_cap;
    }

    size_t size() const { return size_; }
    size_t capacity() const { return capacity_; }

    T& operator[](size_t index) {
        return data[index];
    }
};

这段代码实现了最基本的动态扩容逻辑:

FaceSwapper
FaceSwapper

FaceSwapper是一款AI在线换脸工具,可以让用户在照片和视频中无缝交换面孔。

下载
  • 初始容量为 0;
  • push_back 时发现容量不够,就调用 reserve
  • 每次扩容为原来的两倍;
  • 使用循环拷贝数据到新内存;
  • 最后替换指针并更新容量。

当然实际的 std::vector 还要考虑构造、析构、移动语义等更复杂的细节。


实际 vector 的优化点

标准库中的 std::vector 在实现上会比上面的版本更高效,主要有以下几点优化:

  • 使用 malloc/free 或自定义内存池:减少频繁的内存分配开销。
  • 使用 placement new 和显式调用析构函数:避免不必要的默认构造。
  • 支持移动语义:在扩容时优先使用移动而不是拷贝,提高效率。
  • 异常安全处理:保证在发生异常时不会丢失数据。

这些优化对于性能要求高的场景非常重要,但在理解 vector 底层原理时可以先忽略,先掌握基本结构。


扩容策略为什么选 2 倍?

很多实现中选择每次扩容为原来的两倍,而不是 1.5 倍或其他比例,原因在于时间复杂度分析:

  • 如果每次增加固定长度,比如每次加 10,那插入 n 个元素的时间复杂度是 O(n²);
  • 如果每次乘以某个因子(如 2),则平均插入操作是 O(1),因为摊还分析下每次操作的成本是常数。

虽然 2 倍看起来有点“浪费”,但它能保证整体性能最优。一些语言(如 Java 的 ArrayList)使用的是 1.5 倍,主要是为了节省内存,但代价是扩容次数稍微多一点。


基本上就这些。了解 vector 的底层机制,不仅能帮助你更好地使用它,还能提升你在算法题和系统设计中的表现。如果你想深入研究,建议去看 STL 的源码,比如 GCC 的 libstdc++ 或 MSVC 的 STL 实现。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

398

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

575

2023.08.10

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

418

2023.08.14

2026赚钱平台入口大全
2026赚钱平台入口大全

2026年最新赚钱平台入口汇总,涵盖任务众包、内容创作、电商运营、技能变现等多类正规渠道,助你轻松开启副业增收之路。阅读专题下面的文章了解更多详细内容。

52

2026.01.31

高干文在线阅读网站大全
高干文在线阅读网站大全

汇集热门1v1高干文免费阅读资源,涵盖都市言情、京味大院、军旅高干等经典题材,情节紧凑、人物鲜明。阅读专题下面的文章了解更多详细内容。

40

2026.01.31

无需付费的漫画app大全
无需付费的漫画app大全

想找真正免费又无套路的漫画App?本合集精选多款永久免费、资源丰富、无广告干扰的优质漫画应用,涵盖国漫、日漫、韩漫及经典老番,满足各类阅读需求。阅读专题下面的文章了解更多详细内容。

50

2026.01.31

漫画免费在线观看地址大全
漫画免费在线观看地址大全

想找免费又资源丰富的漫画网站?本合集精选2025-2026年热门平台,涵盖国漫、日漫、韩漫等多类型作品,支持高清流畅阅读与离线缓存。阅读专题下面的文章了解更多详细内容。

11

2026.01.31

漫画防走失登陆入口大全
漫画防走失登陆入口大全

2026最新漫画防走失登录入口合集,汇总多个稳定可用网址,助你畅享高清无广告漫画阅读体验。阅读专题下面的文章了解更多详细内容。

13

2026.01.31

php多线程怎么实现
php多线程怎么实现

PHP本身不支持原生多线程,但可通过扩展如pthreads、Swoole或结合多进程、协程等方式实现并发处理。阅读专题下面的文章了解更多详细内容。

1

2026.01.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 8.1万人学习

C 教程
C 教程

共75课时 | 4.3万人学习

C++教程
C++教程

共115课时 | 15万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号