用C语言解决内存动态管理问题

内存动态管理
使用动态分配内存的方式,模拟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个元素,最后析构函数中释放内存