淘先锋技术网

首页 1 2 3 4 5 6 7

realloc 用方法

void* realloc(void*, n)

  • 根据n的大小,如果n比较小,就沿用原来的内存地址(也就是返回的地址就是原来的地址),在原来地址的内存空间的最后面,加上n大小的内存空间;如果n比较大,系统就不会沿用原来的内存地址,系统有新开辟一个内存空间,并把原来内存空间里存放的值复制过来,这时realloc的返回地址和原来的地址就不同了。
  • 当realloc返回的地址不是原来的地址的时候,realloc函数会释放掉原来地址的内存空间,在这种情况下,如果在realloc调用的后面,free(原来的地址),就会发生吐核(segment fault),所以,最后只需要free(新的地址)就可以了。
#include <stdio.h>
#include <stdlib.h>

int main(){

  int *p = (int*)malloc(sizeof(int) * 5);
  if(NULL == p){

  }
  for(int i = 0; i < 5; ++i){
    *(p + i) = i;
  }

  for(int i = 0; i < 5; ++i){
    printf("%d ",*(p + i));
  }
  printf("\n");

  //由于新要求的空间过大,realloc就会释放掉原来的p指向的空间,然后再从新开辟空间,并把地址返回给p1,这时p和p1就不指向同一个地址了。
  int *p1 = (int*)realloc(p,sizeof(int) * 800000);
  for(int k = 5; k < 8; ++k){
    *(p1 + k) = k;
  }

  for(int i = 0; i < 8; ++i){
    printf("%d ",*(p1 + i));
  }
  printf("\n");

  //free(p); //因为要求新的空间过大,所以就不沿用原来的地址,再释放原来的地址就吐核了;如果要求新的空间不大的话,free(p)和free(p1)哪个都可以,但只能调用其中的一个。                                                                    
  free(p1);//释放新地址的内存空间
}

转载于:https://www.cnblogs.com/xiaoshiwang/p/9157697.html