realloc函数的用法

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

你可能感兴趣的:(数据结构,算法,c语言,数据结构)