void * realloc(旧地址,newsize)
当newsize大于旧地址的容量时,可对旧地址进行扩容操作,规则如下:
首先考虑就近扩容,新的内存区域和旧的内存区域的起始地址相同,即新地址和就地址相同,同时保留旧的内存区域的数据成员,但新内存的容量是newsize。
当就近扩容无法进行,即无法就近申请一块newsize的连续的新地址,此时将申请一块新的容量为newsize的地址,然后将原有数据从头到尾拷贝到新的内存区域。
就近扩容
#include <>
#include <>
int main()
{
int *p;
p=(int *)malloc(sizeof(int)*100);
for(int i=0;i<10;i++){
p[i]=i;
}
int *f=realloc(p,1000);
printf("%p\n",p);
for(int i=0;i<10;i++){
printf("%d\n",f[i]);
}
printf("%p\n",f);
return 0;
}
输出:0000000000165A10
0
1
2
3
4
5
6
7
8
9
0000000000165A10
新开辟空间:
#include <>
#include <>
int main()
{
int *p;
p=(int *)malloc(sizeof(int)*1000);
for(int i=0;i<10;i++){
p[i]=i;
}
int *f=realloc(p,1000000);
printf("%p\n",p);
for(int i=0;i<10;i++){
printf("%d\n",f[i]);
}
printf("%p\n",f);
return 0;
}
输出:
00000000007C5A10
0
1
2
3
4
5
6
7
8
9
0000000000620080