0

0

Vector C用法_C语言中模拟向量容器的实现方法

煙雲

煙雲

发布时间:2026-01-08 11:37:02

|

607人浏览过

|

来源于php中文网

原创

C语言无内置vector因标准库不支持动态数组,需手动管理内存;stb_ds.h等库用宏封装实现高效、轻量的vector功能。

vector c用法_c语言中模拟向量容器的实现方法

为什么 C 语言没有内置 vector,但你仍需要它

C 标准库不提供动态数组容器(如 C++ 的 std::vector),所有数组长度必须编译期确定或手动管理内存。当需要在运行时增删元素、自动扩容时,malloc/realloc + 手动维护长度/容量是唯一选择——这也是“Vector C”类库(如 kcvecvec.hstb_ds)存在的根本原因:把重复的内存管理逻辑封装成可复用的宏或函数集。

stb_ds.h 快速声明和操作 vector

stb_ds.h 是最轻量、头文件即用的 C vector 实现,靠宏展开生成类型专用代码,无运行时开销。它不依赖任何外部库,只需包含单个头文件。

常见操作对应关系:

  • int *arr = NULL; → 声明空 vector(指针初始化为 NULL
  • arr_push(arr, 42); → 尾部插入,自动扩容
  • arr_pop(arr); → 移除并返回最后一个元素
  • arr_len(arr) → 当前元素个数(不是分配字节数)
  • arr_free(arr); → 释放全部内存,指针置为 NULL
#include "stb_ds.h"

int main() { int *v = NULL; arr_push(v, 10); arr_push(v, 20); arr_push(v, 30); printf("len: %d, last: %d\n", arr_len(v), v[arr_len(v)-1]); // len: 3, last: 30 arr_free(v); return 0; }

手写简易 vector 宏时最容易踩的三个坑

自己实现类似 vec_push 的宏,看似简单,实际极易出错。核心问题不在逻辑,而在宏展开时机与副作用。

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

DeepAI
DeepAI

为天生具有创造力的人提供的AI工具

下载
  • 不要在 vec_push 参数里放带副作用的表达式:比如 vec_push(v, i++) 可能导致 i 被计算两次(一次判断容量,一次赋值)
  • 容量增长策略必须是指数级(如 ×1.5 或 ×2),线性增长(每次 +1)会导致 O(n²) 插入复杂度
  • 检查 realloc 返回值是否为 NULL:失败时不更新原指针,否则造成内存泄漏+悬垂指针

一个安全的手写片段示意(仅展示关键判断逻辑):

#define vec_push(vec, elem) do { \
    typeof(*(vec)) *_vec = (vec); \
    size_t _len = vec ? vec_len(vec) : 0; \
    size_t _cap = vec ? vec_cap(vec) : 0; \
    if (_len >= _cap) { \
        size_t new_cap = _cap ? _cap * 2 : 1; \
        typeof(*(vec)) *_new = realloc(_vec, new_cap * sizeof(*(vec))); \
        if (!_new) abort(); /* 或返回错误码 */ \
        (vec) = _new; \
        vec_set_cap(vec, new_cap); \
    } \
    (vec)[_len] = (elem); \
    vec_set_len(vec, _len + 1); \
} while(0)

什么时候不该用 vector 模拟,而该换方案

vector 本质是尾部高效、随机访问快、头部/中间插入极慢的结构。如果你的场景频繁在开头加元素、按条件删除中间项、或需要稳定迭代器,它反而会掩盖性能问题。

  • 需要频繁首部插入/删除 → 改用链表(list.h 或手写 struct node *
  • 需要按值查找后删除 → vector 删除后要 memmove,O(n);考虑哈希表(uthash.h)或先标记再批量 compact
  • 数据量固定且已知上限 → 直接用上数组 + 长度计数器,避免 malloc 开销
  • 跨线程共享 → 所有 vector 宏都不是线程安全的,需额外加锁,此时应评估是否用更高级的并发容器

真正难的从来不是“怎么让 vector 工作”,而是“它是不是当前问题最合适的抽象”。很多 C 项目后期性能瓶颈,追根溯源都是早期把 vector 当万能胶水,往不该塞的地方硬塞。

相关专题

更多
C语言变量命名
C语言变量命名

c语言变量名规则是:1、变量名以英文字母开头;2、变量名中的字母是区分大小写的;3、变量名不能是关键字;4、变量名中不能包含空格、标点符号和类型说明符。php中文网还提供c语言变量的相关下载、相关课程等内容,供大家免费下载使用。

383

2023.06.20

c语言入门自学零基础
c语言入门自学零基础

C语言是当代人学习及生活中的必备基础知识,应用十分广泛,本专题为大家c语言入门自学零基础的相关文章,以及相关课程,感兴趣的朋友千万不要错过了。

609

2023.07.25

c语言运算符的优先级顺序
c语言运算符的优先级顺序

c语言运算符的优先级顺序是括号运算符 > 一元运算符 > 算术运算符 > 移位运算符 > 关系运算符 > 位运算符 > 逻辑运算符 > 赋值运算符 > 逗号运算符。本专题为大家提供c语言运算符相关的各种文章、以及下载和课程。

349

2023.08.02

c语言数据结构
c语言数据结构

数据结构是指将数据按照一定的方式组织和存储的方法。它是计算机科学中的重要概念,用来描述和解决实际问题中的数据组织和处理问题。数据结构可以分为线性结构和非线性结构。线性结构包括数组、链表、堆栈和队列等,而非线性结构包括树和图等。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

255

2023.08.09

c语言random函数用法
c语言random函数用法

c语言random函数用法:1、random.random,随机生成(0,1)之间的浮点数;2、random.randint,随机生成在范围之内的整数,两个参数分别表示上限和下限;3、random.randrange,在指定范围内,按指定基数递增的集合中获得一个随机数;4、random.choice,从序列中随机抽选一个数;5、random.shuffle,随机排序。

592

2023.09.05

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

520

2023.09.20

c语言get函数的用法
c语言get函数的用法

get函数是一个用于从输入流中获取字符的函数。可以从键盘、文件或其他输入设备中读取字符,并将其存储在指定的变量中。本文介绍了get函数的用法以及一些相关的注意事项。希望这篇文章能够帮助你更好地理解和使用get函数 。

634

2023.09.20

c数组初始化的方法
c数组初始化的方法

c语言数组初始化的方法有直接赋值法、不完全初始化法、省略数组长度法和二维数组初始化法。详细介绍:1、直接赋值法,这种方法可以直接将数组的值进行初始化;2、不完全初始化法,。这种方法可以在一定程度上节省内存空间;3、省略数组长度法,这种方法可以让编译器自动计算数组的长度;4、二维数组初始化法等等。

599

2023.09.22

Golang 分布式缓存与高可用架构
Golang 分布式缓存与高可用架构

本专题系统讲解 Golang 在分布式缓存与高可用系统中的应用,涵盖缓存设计原理、Redis/Etcd集成、数据一致性与过期策略、分布式锁、缓存穿透/雪崩/击穿解决方案,以及高可用架构设计。通过实战案例,帮助开发者掌握 如何使用 Go 构建稳定、高性能的分布式缓存系统,提升大型系统的响应速度与可靠性。

27

2026.01.09

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
HTML5/CSS3/JavaScript/ES6入门课程
HTML5/CSS3/JavaScript/ES6入门课程

共102课时 | 6.6万人学习

前端基础到实战(HTML5+CSS3+ES6+NPM)
前端基础到实战(HTML5+CSS3+ES6+NPM)

共162课时 | 18.6万人学习

第二十二期_前端开发
第二十二期_前端开发

共119课时 | 12.2万人学习

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

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