0

0

C++动态数组扩容 自定义扩容策略实现

P粉602998670

P粉602998670

发布时间:2025-08-26 12:32:01

|

447人浏览过

|

来源于php中文网

原创

动态数组扩容通过调整容量平衡性能与内存,常见策略有倍增、线性及1.5倍增长,结合函数指针可灵活切换,提升特定场景下的效率表现。

c++动态数组扩容 自定义扩容策略实现

在C++中,动态数组扩容是实现类似

std::vector
功能的核心机制。当现有容量不足以容纳新元素时,需要重新分配更大的内存空间,并将原有数据迁移过去。自定义扩容策略可以优化性能,适应不同场景下的内存和速度需求。

扩容的基本原理

动态数组通常包含三个核心指针或变量:

  • data:指向堆上分配的内存首地址
  • size:当前已存储的元素个数
  • capacity:当前可容纳的最大元素数量(无需扩容)

当插入元素时,若

size == capacity
,则触发扩容。扩容步骤如下:

  1. 根据策略计算新的容量
  2. 分配新内存块
  3. 将旧数据复制或移动到新内存
  4. 释放旧内存
  5. 更新
    data
    capacity

常见扩容策略对比

不同策略在内存使用和时间开销之间权衡:

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

  • 倍增策略(如×1.5或×2):常见于STL容器,摊还插入时间O(1),但可能浪费较多内存
  • 线性增长(如+固定值):内存友好,但频繁扩容导致性能下降
  • Fibonacci增长:折中方案,增长速度介于线性和指数之间

自定义策略实现示例

下面是一个支持自定义扩容策略的动态数组模板:

瑞志企业建站系统(ASP版)2.2
瑞志企业建站系统(ASP版)2.2

支持模板化设计,基于标签调用数据 支持N国语言,并能根据客户端自动识别当前语言 支持扩展现有的分类类型,并可修改当前主要分类的字段 支持静态化和伪静态 会员管理功能,询价、订单、收藏、短消息功能 基于组的管理员权限设置 支持在线新建、修改、删除模板 支持在线管理上传文件 使用最新的CKEditor作为后台可视化编辑器 支持无限级分类及分类的移动、合并、排序 专题管理、自定义模块管理 支持缩略图和图

下载
template
class DynamicArray {
private:
    T* data;
    size_t size;
    size_t cap;
// 扩容策略函数指针
size_t (*growth_strategy)(size_t);

void reallocate() {
    size_t new_cap = growth_strategy(cap);
    T* new_data = new T[new_cap];

    for (size_t i = 0; i zuojiankuohaophpcn size; ++i) {
        new_data[i] = std::move(data[i]);
    }

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

public: explicit DynamicArray(size_t initial_cap = 10, size_t (*strategy)(size_t) = default_strategy) : data(new T[initial_cap]) , size(0) , cap(initial_cap) , growth_strategy(strategy) {}

~DynamicArray() {
    delete[] data;
}

void push_back(const T& value) {
    if (size == cap) reallocate();
    data[size++] = value;
}

void push_back(T&& value) {
    if (size == cap) reallocate();
    data[size++] = std::move(value);
}

T& operator[](size_t index) { return data[index]; }
const T& operator[](size_t index) const { return data[index]; }
size_t length() const { return size; }
size_t capacity() const { return cap; }

// 默认策略:容量翻倍
static size_t default_strategy(size_t current) {
    return current == 0 ? 1 : current * 2;
}

// 线性增长策略
static size_t linear_strategy(size_t current) {
    return current + 10;
}

// 1.5倍增长策略
static size_t multiplicative_strategy(size_t current) {
    return current == 0 ? 1 : current + (current >> 1); // current * 1.5
}

};

使用示例与策略选择

根据应用场景选择合适的策略:

int main() {
    // 使用默认翻倍策略
    DynamicArray arr1(8);
// 使用1.5倍增长,减少内存浪费
DynamicArrayzuojiankuohaophpcnintyoujiankuohaophpcn arr2(8, DynamicArrayzuojiankuohaophpcnintyoujiankuohaophpcn::multiplicative_strategy);

// 使用线性增长,适用于小数据量且内存敏感场景
DynamicArrayzuojiankuohaophpcnintyoujiankuohaophpcn arr3(8, DynamicArrayzuojiankuohaophpcnintyoujiankuohaophpcn::linear_strategy);

for (int i = 0; i zuojiankuohaophpcn 100; ++i) {
    arr1.push_back(i);
}

return 0;

}

选择策略时考虑:

  • 若频繁插入且性能优先,推荐倍增或1.5倍策略
  • 若内存受限或数据量可预估,线性增长更合适
  • 可设计更复杂的策略,如根据当前容量分段处理

基本上就这些。自定义扩容策略的关键在于平衡内存开销和复制成本,通过函数指针或模板参数灵活切换策略,能有效提升容器在特定场景下的表现。

相关专题

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

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

391

2023.07.18

堆和栈区别
堆和栈区别

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

572

2023.08.10

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

72

2026.01.16

全民K歌得高分教程大全
全民K歌得高分教程大全

本专题整合了全民K歌得高分技巧汇总,阅读专题下面的文章了解更多详细内容。

131

2026.01.16

C++ 单元测试与代码质量保障
C++ 单元测试与代码质量保障

本专题系统讲解 C++ 在单元测试与代码质量保障方面的实战方法,包括测试驱动开发理念、Google Test/Google Mock 的使用、测试用例设计、边界条件验证、持续集成中的自动化测试流程,以及常见代码质量问题的发现与修复。通过工程化示例,帮助开发者建立 可测试、可维护、高质量的 C++ 项目体系。

54

2026.01.16

java数据库连接教程大全
java数据库连接教程大全

本专题整合了java数据库连接相关教程,阅读专题下面的文章了解更多详细内容。

39

2026.01.15

Java音频处理教程汇总
Java音频处理教程汇总

本专题整合了java音频处理教程大全,阅读专题下面的文章了解更多详细内容。

19

2026.01.15

windows查看wifi密码教程大全
windows查看wifi密码教程大全

本专题整合了windows查看wifi密码教程大全,阅读专题下面的文章了解更多详细内容。

85

2026.01.15

浏览器缓存清理方法汇总
浏览器缓存清理方法汇总

本专题整合了浏览器缓存清理教程汇总,阅读专题下面的文章了解更多详细内容。

43

2026.01.15

热门下载

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

精品课程

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

共94课时 | 7万人学习

C 教程
C 教程

共75课时 | 4.1万人学习

C++教程
C++教程

共115课时 | 12.8万人学习

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

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