嵌入式面试经典问题(使用C语言实现不定长数组)
🧱 方法 1:结构体 + 指针 + realloc(最常见)
✅ 实现思路:
使用结构体封装数组指针、容量、当前长度,扩容时用 realloc
。
#include <stdio.h> #include <stdlib.h> typedef struct { int *data; size_t size; // 当前元素数 size_t capacity; // 当前容量 } DynArray; void initArray(DynArray *arr, size_t initCapacity) { arr->data = malloc(initCapacity * sizeof(int)); arr->size = 0; arr->capacity = initCapacity; } void pushBack(DynArray *arr, int value) { if (arr->size >= arr->capacity) { size_t newCap = arr->capacity * 2; int *newData = realloc(arr->data, newCap * sizeof(int)); if (!newData) { perror("realloc failed"); exit(1); } arr->data = newData; arr->capacity = newCap; } arr->data[arr->size++] = value; } void freeArray(DynArray *arr) { free(arr->data); arr->data = NULL; arr->size = arr->capacity = 0; }
🧱 方法 2:柔性数组(C99)
✅ 实现思路:
结构体最后一个成员为未定长数组 int data[]
,分配整块内存。
#include <stdio.h> #include <stdlib.h> typedef struct { size_t size; size_t capacity; int data[];
剩余60%内容,订阅专栏后可继续查看/也可单篇购买
嵌入式面试八股文全集 文章被收录于专栏
这是一个全面的嵌入式面试专栏。主要内容将包括:操作系统(进程管理、内存管理、文件系统等)、嵌入式系统(启动流程、驱动开发、中断管理等)、网络通信(TCP/IP协议栈、Socket编程等)、开发工具(交叉编译、调试工具等)以及实际项目经验分享。专栏将采用理论结合实践的方式,每个知识点都会附带相关的面试真题和答案解析。