C动态分配内存注意事项
众所周知,realloc()
的作用就是将已经 malloc 的内存块,重新扩展加长。当你并没有使用高端的内存池的时候,临时从堆中申请加大内存,这是很有用的。但是如何正确地使用 realloc() 呢?
调用方法
函数原型
#include <stdlib.h>
void *realloc(void *ptr, size_t size);
传入参数:
(1)需要被扩展大小的内存指针
(2)扩展后的大小(注意不是添加的大小)
返回参数:
新的指针
当 realloc()
返回非零值时呢,表示realloc是成功的。此时不论返回值是多少,程序都不需要对原来的内存地址值作特殊操作
。
为什么这么说呢?主要是参考资料里面没有把一个问题说清楚:
- 首先,如果
pMemToBeRealloc == pMemBackup
的情况,那说明只是在原来的内存基础上往后扩展就好了,这是最简单的情况 -
可是如果
pMemToBeRealloc != pMemBackup
呢?这很容易让人误解为,需要调用一次 free(pMemBackup)。这是错误的,因为这个动作,realloc 会自动帮你做了,不要画蛇添足!
下面总结一下C的内存操作函数。动态内存分配(malloc colloc realloc free)
malloc和free
malloc是C语言库提供用于动态内存分配的函数,而free用于释放所分配的内存。
他们所包含在stdlib.h中,原型是:
void *malloc(size_t size)
void free(void *pointer)
malloc的参数就是需要分配的内存字节数。如果内存池中的可用内存可以满足这个需求,malloc就返回一个指向被分配的内存块起始指针所指向的位置。
如果没有足够的内存,就返回NULL,所以,对于malloc返回的指针都得检查是否为空。
free的参数要么就是NULL,要么就是从malloc返回的值。但是不能free一部分内存,而且,已经释放的内存也不能重复释放。
colloc和realloc
内存分配除了malloc还有两个,就是colloc和realloc
他们的原型是:
void *colloc(size_t num_elements,size_t elements_size);
void realloc(void*ptr,size-t new_size);
colloc和malloc的区别:
1、前者除了分配的内存外还要在返回指针之前将其初始化为0,而后者没初始化。初始化有时候很方便,但是有时候要是不需要初始化,那就浪费时间了,所以这个根据实际情况而定。
2、参数不同,colloc的参数有两个,前一个是所需元素的数量,后一个是每个元素的字节数(基本单位)。
我们用malloc开辟一段内存,一直用着好好地,但是当我们发现这段内存不够了,或是我们根本不需要这么多的内存了,咋办?
这时候就是realloc出场的时候了:
realloc用于修改原来分配的内存的大小。使用这个函数,可以将内存扩大或是缩小。
如果是扩大内存,那么原内存将会保留,新增的内存会加在原来的内存后面;如果是缩小内存,那么原内存块的尾部内存将会被拿掉,剩余的内存保留。如果原内存无法改变大小,realloc将会分配 另一块正确大小的内存,并把原来的内存复制到新的内存块上。因此在使用realloc之后,不能再使用原来的内存指针,而是应该改用realloc所返回的新指针。
动态内存必须整块一起释放,但是realloc函数可以缩小一块动态内存的内存,有效的释放尾部的部分内存。
上一篇: Redis数据库结构以及键空间的操作
推荐阅读