C/C++ realloc()函数解析
真是有點慚愧,這些內容本應該很早就掌握的,以前只是糊里糊涂的用,不知道在內存中具體是怎么回事,現在才弄清楚。
realloc(void *__ptr, size_t __size):更改已經配置的內存空間,即更改由malloc()函數分配的內存空間的大小。
如果將分配的內存減少,realloc僅僅是改變索引的信息。
如果是將分配的內存擴大,則有以下情況:
1)如果當前內存段后面有需要的內存空間,則直接擴展這段內存空間,realloc()將返回原指針。
2)如果當前內存段后面的空閑字節不夠,那么就使用堆中的第一個能夠滿足這一要求的內存塊,將目前的數據復制到新的位置,并將原來的數據塊釋放掉,返回新的內存塊位置。
3)如果申請失敗,將返回NULL,此時,原來的指針仍然有效。
注意:如果調用成功,不管當前內存段后面的空閑空間是否滿足要求,都會釋放掉原來的指針,重新返回一個指針,雖然返回的指針有可能和原來的指針一樣,即不能再次釋放掉原來的指針。
看一下示例代碼
#include <stdio.h> #include <stdlib.h>int main(int argc, char* argv[], char* envp[]) {int input;int n;int *numbers1;int *numbers2;numbers1=NULL;if((numbers2=(int *)malloc(5*sizeof(int)))==NULL)//為numbers2在堆中分配內存空間{printf("malloc memory unsuccessful");exit(1);}printf("numbers2 addr: %8X\n",(int)numbers2);for(n=0;n<5;n++) //初始化{*(numbers2+n)=n;//printf("numbers2's data: %d\n",*(numbers2+n));}printf("Enter new size: ");scanf("%d",&input);//重新分配內存空間,如果分配成功的話,就釋放numbers2指針,//但是并沒有將numbers2指針賦為NULL,也就是說釋放掉的是系統分配的堆空間,//和該指針沒有直接的關系,現在仍然可以用numbers2來訪問這部分堆空間,但是//現在的堆空間已經不屬于該進程的了。numbers1=(int *)realloc(numbers2,(input+5)*sizeof(int));if(numbers1==NULL){printf("Error (re)allocating memory");exit(1);}printf("numbers1 addr: %8X\n",(int)numbers1);/*for(n=0;n<5;n++) //輸出從numbers2拷貝來的數據{printf("the numbers1's data copy from numbers2: %d\n",*(numbers1+n));}*/for(n=0;n<input;n++)//新數據初始化{*(numbers1+5+n)=n+5;//printf("numbers1' new data: %d\n",*(numbers1+5+n));}printf("\n");free(numbers1);//釋放numbers1,此處不需要釋放numbers1,因為在realloc()時已經釋放numbers1=NULL;//free(numbers2);//不能再次釋放,有博友說不需要釋放:應該其實不需要自己釋放number2return 0; }如果當前內存段后有足夠的空間,realloc()返回原來的指針:
yugsuo@ubuntu:~/linux/memange$ gcc -g -o realloc realloc_example.c?
yugsuo@ubuntu:~/linux/memange$ ./realloc?
numbers2 addr: ?8AFC008
Enter new size: 10
numbers1 addr: ?8AFC008
如果當前內存段后沒有足夠的空間,realloc()返回一個新的內存段的指針:
yugsuo@ubuntu:~/linux/memange$ ./realloc
numbers2 addr: 9505008
Enter new size: 1000000
numbers1 addr: B716F008
總結
以上是生活随笔為你收集整理的C/C++ realloc()函数解析的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Linux 查看 占用内存最多 占用cp
- 下一篇: eclipse常用设置及调试快捷键