内存动态管理
使用动态分配内存的方式,模拟C++中Vector容器,实现动态数组的构建。
写一个函数,先用malloc开辟一定大小的空间,记住这个空间的大小,每次使用的时候都用if判断一次,如果已经满了,就对原有动态内存空间进行realloc拓宽
C语言动态内存管理👉https://blog.csdn.net/muxuen/article/details/122744394?spm=1001.2014.3001.5502
比如下面这个通讯录函数,先开辟了DEFAULT_SZ个结构体大小的空间,如果不够,就再扩容5个
//初始化
void Initial(Contact* pc)
{
assert(pc);
pc->sz = 0;
PeoInfo* tmp = (PeoInfo*)calloc(DEFAULT_SZ, sizeof(PeoInfo));
if (tmp != NULL)
{
pc->data = tmp;
}
else
{
printf("Initial()::%s\n", strerror(errno));
return;
}
pc->capacity = DEFAULT_SZ;
}
//释放通讯录
void DestroyContact(Contact* pc)
{
assert(pc);
free(pc->data);
pc->data = NULL;
pc->sz = 0;
pc->capacity = 0;
}
void CheckCapacity(Contact* pc)
{
if (pc->sz == DEFAULT_SZ)
{
PeoInfo* tmp = (PeoInfo*)realloc(pc->data,(pc->capacity + 5)*sizeof(PeoInfo));
if (tmp != NULL)
{
pc->data = tmp;
pc->capacity += 5;
printf("扩容成功\n");
}
else
{
printf("CheckCapacity()::%s\n", strerror(errno));
return;
}
}
}
//增加联系人
void AddContact(Contact* pc)
{
assert(pc);
CheckCapacity(pc);//查看是否需要扩容
printf("输入姓名>");
scanf("%s", pc->data[pc->sz].name);
printf("输入年龄>");
scanf("%d", &(pc->data[pc->sz].age));
printf("输入性别>");
scanf("%s", pc->data[pc->sz].sex);
printf("输入电话>");
scanf("%s", pc->data[pc->sz].pho);
printf("输入地址>");
scanf("%s", pc->data[pc->sz].adr);
pc->sz++;
printf("增加联系人成功\n");
}
如果对你有帮助,请采纳啊一下,感谢!
开始先分配一定的内存,内存不够了,分配大一点的,比如多分配128个元素,最后析构函数中释放内存