【C语言基础】C++ 中的 `vector` 及其 C 语言实现详解

一、C++ 中的 vector:动态数组的核心特性

1. 基本概念
vector 是 C++ 标准模板库(STL)中的动态数组容器,支持自动扩容、高效元素访问和丰富的操作接口。其核心特性包括:

  • 动态内存管理:自动调整容量,避免手动管理内存。
  • 连续存储:元素在内存中连续存放,支持随机访问(时间复杂度 O(1))。
  • 类型安全:通过模板实现,支持任意数据类型。

2. 核心操作

  • 初始化与遍历
    #include <vector>
    std::vector<int> vec = {1, 2, 3}; // 初始化
    for (int num : vec) { /* 范围循环 */ }
    
  • 插入与删除
    vec.push_back(4);    // 尾部插入
    vec.pop_back();      // 尾部删除
    vec.insert(vec.begin() + 1, 5); // 中间插入
    vec.erase(vec.begin());         // 中间删除
    
  • 容量管理
    vec.reserve(100);    // 预分配容量
    vec.shrink_to_fit(); // 释放多余内存
    

3. 性能优化

  • 扩容策略:默认容量翻倍增长,可通过 reserve 减少扩容次数。
  • 移动语义(C++11+):避免深拷贝,提升对象传递效率。

4. 适用场景

  • 需要动态调整大小的数组(如读取未知数量数据)。
  • 高频随机访问元素的场景(如排序、查找)。

二、C 语言实现动态数组(仿 vector

1. 结构设计
通过结构体封装动态数组的核心参数:

typedef struct {void* data;         // 数据指针size_t size;        // 当前元素数量size_t capacity;    // 分配的总容量size_t elem_size;   // 单个元素大小(字节)
} Vector;

2. 核心功能实现

  • 初始化与销毁

    Vector vector_init(size_t elem_size, size_t capacity) {Vector vec;vec.elem_size = elem_size;vec.capacity = (capacity > 0) ? capacity : 1;vec.data = malloc(vec.capacity * elem_size);return vec;
    }void vector_destroy(Vector* vec) {free(vec->data);vec->data = NULL;
    }
    
  • 动态扩容

    void vector_resize(Vector* vec, size_t new_capacity) {void* new_data = realloc(vec->data, new_capacity * vec->elem_size);vec->data = new_data;vec->capacity = new_capacity;
    }
    
  • 元素操作

    void vector_push_back(Vector* vec, const void* value) {if (vec->size >= vec->capacity) {vector_resize(vec, vec->capacity * 2); // 容量翻倍}memcpy((char*)vec->data + vec->size * vec->elem_size, value, vec->elem_size);vec->size++;
    }void* vector_at(Vector* vec, size_t index) {return (char*)vec->data + index * vec->elem_size;
    }
    

3. 使用示例

int main() {Vector vec = vector_init(sizeof(int), 2);int a = 10, b = 20;vector_push_back(&vec, &a);vector_push_back(&vec, &b);printf("%d", *(int*)vector_at(&vec, 1)); // 输出 20vector_destroy(&vec);return 0;
}

三、C++ vector 与 C 实现的对比
特性C++ vectorC 实现
内存管理自动扩容与释放(RAII)需手动调用 resizedestroy
类型安全模板支持,编译时类型检查依赖 void*,需手动类型转换
功能扩展支持迭代器、STL 算法需自行实现排序、查找等功能
性能优化移动语义、预分配策略需手动优化内存对齐或批量操作
异常处理抛出 std::out_of_range 等异常直接终止程序或返回错误码

四、开发建议
  1. C++ 场景

    • 优先使用 vector,避免重复造轮子。
    • 结合 reserveemplace_back 提升性能。
  2. C 语言场景

    • 封装内存操作函数(如 vector_push_bulk)减少冗余代码。
    • 添加边界检查宏增强安全性:
      #define VECTOR_SAFE_ACCESS(vec, index) \((index < vec.size) ? vector_at(&vec, index) : NULL)
      
  3. 跨语言协作

    • 在混合编程时,可通过 C 动态数组传递数据,再由 C++ 封装为 vector

五、总结

C++ 的 vector 通过模板和标准库支持,提供了高效便捷的动态数组操作;而 C 语言需手动实现类似功能,虽灵活性高,但开发成本较大。理解两者的底层机制,有助于在不同场景下合理选择数据结构,优化程序性能与可维护性。

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

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

相关文章

nvm切换node版本后,解决npm找不到的问题

解决方法如下 命令行查看node版本 node -v找到node版本所对应的npm版本 点击进入node版本 npm对应版本下载 点击进入npm版本 下载Windows 压缩包 下载完成后&#xff0c;解压&#xff0c;文件改名为npm 复制到你nvm对应版本的node_modules 下面 将下载的npm /bin 目录…

数据结构:最小生成树的普里姆算法和克鲁斯卡尔算法

对于一个带权&#xff08;假设每条边上的权均为大于零的实数&#xff09;连通无向图 G 中的不同生成树&#xff0c;其每棵树的所有边上的权值之和也可能不同&#xff1b;图的所有生成树中具有边上的权值之和最小的树称为图的最小生成树&#xff08;Minimal Spanning Tree&#…

Information-Theoretic Limits of Bistatic Integrated Sensing and Communication

摘要 双静态感知指的是发射器&#xff08;照亮目标&#xff09;和感知接收器&#xff08;估计目标状态&#xff09;在物理上分离的场景&#xff0c;这与发射和感知功能共存的单静态感知形成对比。在实际场景中&#xff0c;双静态感知可能需要应对系统约束&#xff0c;或者作为…

XCTF-web(四)

unserialize3 需要反序列化一下&#xff1a;O:4:“xctf”:2:{s:4:“flag”;s:3:“111”;} php_rce 题目提示rce漏洞&#xff0c;测试一下&#xff1a;?s/Index/\think\app/invokefunction&functioncall_user_func_array&vars[0]phpinfo&vars[1][]1 flag&#xff1…

Java Stream深度解析 高阶技巧与性能优化实战

文章目录 一、Stream底层机制揭秘1.1 Stream流水线架构1.2 Spliterator探秘 二、自定义收集器高级实现2.1 实现高性能统计收集器2.2 多级分组优化技巧 三、并行流深度优化3.1 并行度控制策略3.2 工作窃取(Work-Stealing)优化 四、无限流与短路操作4.1 生成无限质数流4.2 短路操…

TailwindCss快速上手

什么是Tailwind Css? 一个实用优先的 CSS 框架&#xff0c;可以直接在标记中组合以构建任何设计。 开始使用Tailwind Css 如何安装 下面是使用vite构建工具的方法 ①安装 Tailwind CSS: tailwindcss通过tailwindcss/vitenpm安装。 npm install tailwindcss tailwindcss…

Web前端 (CSS篇)

什么是CSS&#xff1f; css(Cascading Style Sheets)是层叠样式表或级联样式表&#xff0c;是一组设置规则&#xff0c;用于控制web页面外观。 为什么使用CSS? CSS 用于定义网页的样式&#xff0c;包括针对不同设备和屏幕尺寸的设计和布局。 CSS 实例 body {background-col…

微服务2--服务治理与服务调用

前言 &#xff1a;本文主要阐述微服务架构中的服务治理&#xff0c;以及Nacos环境搭建、服务注册、服务调用&#xff0c;负载均衡以及Feign实现服务调用。 服务治理 服务治理是微服务架构中最核心最基本的模块。用于实现各个微服务的自动化注册与发现。 服务注册&#xff1a;在…

智能麻将出牌组件

开篇引言​ 麻将作为一款风靡全球的策略性游戏&#xff0c;其复杂的规则和多变的牌局给玩家带来了无尽乐趣。在数字化时代&#xff0c;运用编程技术为麻将游戏赋予智能&#xff0c;实现自动出牌功能&#xff0c;不仅能提升玩家体验&#xff0c;还能深入探索算法在博弈游戏中的…

“大湾区珠宝艺境花园”璀璨绽放第五届消博会

2025年4月13日&#xff0c;第五届中国国际消费品博览会&#xff08;以下简称"消博会"&#xff09;重要主题活动——《大湾区珠宝艺境花园》启动仪式在海南国际会展中心2号馆隆重举行。由广东省金银珠宝玉器业厂商会组织带领粤港澳大湾区优秀珠宝品牌&#xff0c;以“…

基于前端技术的QR码API开发实战:从原理到部署

前言 QR码&#xff08;Quick Response Code&#xff09;是一种二维码&#xff0c;于1994年开发。它能快速存储和识别数据&#xff0c;包含黑白方块图案&#xff0c;常用于扫描获取信息。QR码具有高容错性和快速读取的优点&#xff0c;广泛应用于广告、支付、物流等领域。通过扫…

利用耦合有限元和神经网络计算的骨重塑模拟多尺度方法

Multiscale methodology for bone remodelling simulation using coupled finite element and neural network computation 摘要&#xff1a;本文旨在开发一种基于有限元分析&#xff08;FEA&#xff09;和神经网络&#xff08;NN&#xff09;计算的多尺度分层混合模型&#xf…

使用异步特征引发的错误error[E0195]: lifetime parameters or bounds on method `before_save`

问题描述&#xff1a; 使用SeaOrm保存实体到数据库时不想每次都设置更新时间&#xff0c;所以想通过实现ActiveModelBehavior在保存实体前统一设置更新时间 impl ActiveModelBehavior for ActiveModel {async fn before_save<C>(self, _db: &C, _insert: bool) -&…

TVS管与ESD保护二极管详解:原理、区别与应用选型

一、TVS管&#xff08;瞬态电压抑制二极管&#xff09; 1. 基本定义 TVS管&#xff08;Transient Voltage Suppressor&#xff09; 是一种用于抑制瞬态高压脉冲的半导体器件&#xff0c;通过雪崩击穿效应快速钳位电压&#xff0c;保护后端电路。 2. 核心特性参数 参数定义公…

Day08 【基于jieba分词实现词嵌入的文本多分类】

基于jieba分词的文本多分类 目标数据准备参数配置数据处理模型构建主程序测试与评估测试结果 目标 本文基于给定的词表&#xff0c;将输入的文本基于jieba分词分割为若干个词&#xff0c;然后将词基于词表进行初步编码&#xff0c;之后经过网络层&#xff0c;输出在已知类别标…

入门-C编程基础部分:6、常量

飞书文档https://x509p6c8to.feishu.cn/wiki/MnkLwEozRidtw6kyeW9cwClbnAg C 常量 常量是固定值&#xff0c;在程序执行期间不会改变&#xff0c;可以让我们编程更加规范。 常量可以是任何的基本数据类型&#xff0c;比如整数常量、浮点常量、字符常量&#xff0c;或字符串字…

第二阶段:数据结构与函数

模块4&#xff1a;常用数据结构 (Organizing Lots of Data) 在前面的模块中&#xff0c;我们学习了如何使用变量来存储单个数据&#xff0c;比如一个数字、一个名字或一个布尔值。但很多时候&#xff0c;我们需要处理一组相关的数据&#xff0c;比如班级里所有学生的名字、一本…

【C++算法】61.字符串_最长公共前缀

文章目录 题目链接&#xff1a;题目描述&#xff1a;解法C 算法代码&#xff1a;解释 题目链接&#xff1a; 14. 最长公共前缀 题目描述&#xff1a; 解法 解法一&#xff1a;两两比较 先算前两个字符串的最长公共前缀&#xff0c;然后拿这个最长公共前缀和后面一个来比较&…

JVM 调优不再难:AI 工具自动生成内存优化方案

在 Java 应用程序的开发与运行过程中&#xff0c;Java 虚拟机&#xff08;JVM&#xff09;的性能调优一直是一项极具挑战性的任务&#xff0c;尤其是内存优化方面。不合适的 JVM 内存配置可能会导致应用程序出现性能瓶颈&#xff0c;甚至频繁抛出内存溢出异常&#xff0c;影响业…

纷析云开源财务软件:企业财务数字化转型的灵活解决方案

纷析云是一家专注于开源财务软件研发的公司&#xff0c;自2018年成立以来&#xff0c;始终以“开源开放”为核心理念&#xff0c;致力于通过技术创新助力企业实现财务管理的数字化与智能化转型。其开源财务软件凭借高扩展性、灵活部署和全面的功能模块&#xff0c;成为众多企业…