realloc 使用和思考

realloc来自c语言的标准库,函数签名如下:

extern void*  realloc(void *, size_t);

这个函数用于重新分配指针地址对应的内存空间。第一个参数,需要重新分配内存空间的指针。第二个,参数重新分配的内存空间大小。

特别之处在于,realloc在增加内存的情况下,就是size_t大于原有指针内存空间大小,首先会试图去追加地址空间。比如:

char* p = malloc(100);
 
// 这里会试图在p地址内存空间后面追加一个字节空间
// 如果发现后面空间地址被使用
// 这时候才会重新分配内存空间
char* q = realloc(p, 101);

如果需要重新分配内存空间,就会把原有的数据拷贝过来,以后释放原有空间。这时候返回的指针地址和原有的不同。但如果是追加,那么返回指针地址和原有相同。

 

还有个特别之处在于,如果我realloc的大小比原有内存空间小怎么办,比如:

char* p = malloc(100);
 
char* q = realloc(p, 80);

这种情况下,p指针和q指针必定指向同一空间,只是对应内存空间会减小20个字节。这个特性是我查看msdn文档,和C99规范得出的结论。

 

需要注意的是,如果realloc失败那么将会返回NULL,所以这种情况下原指针地址空间还是需要自己维护的。

 

思考: 关于很多语言的动态数组实现,一般的策略都是有个增长因子和增长阀值。当数组长度到达阀值的时候,会动态增长一段内存。就是申请更大的内存地址,把原有的数据拷贝过去,销毁原有的。那么,看到realloc的特性之后,realloc总是会首先试图追加内存空间,这就避免复制销毁的开销提高了性能。还能够剪裁数组内存,可以某些时候剪裁掉多余的动态数组空间,节省内存开销。


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值