realloc 可以对给定的指针所指的空间进行扩大或者缩小,原有内存的中内容将保持不变。当然,对于缩小,则被缩小的那一部分的内容会丢失。
因为realloc是从堆上分配内存的,当扩大一块内存空间时, realloc直接从堆上现存的数据后面的那些字节中获得附加的字节;但如果数据后面的字节不够的话,那么就使用堆上第一个有足够大小的自由块,现存的数据然后就被拷贝至新的位置,而老块则放回到堆上。
在代码中,如果我们采用i = (int*)realloc(i, 2*sizeof(int))的重新分配内存方式,有以下两种情况:
1.分配成功,返回void*指针:realloc返回值如果与前面malloc的值不同,那么realloc函数完成后,i指向的旧内存自动free掉。
2.分配失败,返回NULL值:此时,i原来指向的内存还没有被free掉,而现在又找不到地址,这样就出现memory leak了。
解决办法:定义另一个指针j用于接收realloc返回值,判断是否成功,成功则将j赋给i
#include <stdio.h>
#include <stdlib.h>
#include <iostream>
using namespace std;
void setVal(char *tmp,int qs,int num,char mm)
{
for(int i=qs;i<num-1;i++)
{
*(tmp+i)=mm;
}
*(tmp+num-1)='\0';
}
int main()
{
char *p,*q;
//缩短内存
p = (char * ) malloc (1000);
setVal(p,0,1000,'a');
q = (char *) realloc (p,800);
if(q!=NULL)
{
setVal(q,795,800,'S');
cout<<q<<endl;
cout<<"Success"<<endl;
}
else
{
setVal(p,500,800,'F');
cout<<"Fail"<<endl;
}
free(q);
getchar();
getchar();
system("pause");
return 0;
}