重读数据结构——线性表

本文介绍了如何通过malloc函数初始化顺序表的过程,包括内存分配、初始化长度和大小等步骤,并探讨了realloc函数的功能,用于调整已分配内存块的大小。

Status InitList_Sq(SqList &L) {

    L.elem = (ElemType *)malloc(LIST_INIT_SIZE * sizeof(ElemType));

    if(! L.elem) exit(OVERFLOW);

    L.length = 0;

    L.listsize = LIST_INIT_SIZE;

    return OK;

}

原型:extern void *malloc(unsigned int num_bytes);

功能:分配长度为num_bytes字节的内存块

返回值:如果分配成功则返回指向被分配内存的 指针(此存储区中的初始值不确定),否则返回空指针NULL。当内存不再使用时,应使用 free()函数将内存块释放。函数返回的 指针一定要适当对齐,使其可以用于任何 数据对象

    Malloc 向系统申请分配指定size个字节的内存空间。返回类型是 void* 类型。void* 表示未确定类型的指针。C,C++规定,void* 类型可以强制转换为任何其它类型的指针


原型:extern void *realloc(void *mem_address, unsigned int newsize);

功能:先判断当前的指针是否有足够的连续空间,如果有,扩大mem_address指向的地址,并且将mem_address返回,如果空间不够,先按照newsize指定的大小分配空间,将原有数据从头到尾拷贝到新分配的内存区域,而后释放原来mem_address所指内存区域,同时返回新分配的内存区域的首地址。即重新分配存储器块的地址。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值