c: realloc()函数解析
realloc(void *__ptr, size_t __size):更改已經(jīng)配置的內(nèi)存空間,即更改由malloc()函數(shù)分配的內(nèi)存空間的大小。
如果將分配的內(nèi)存減少,realloc僅僅是改變索引的信息。
如果是將分配的內(nèi)存擴(kuò)大,則有以下情況:
1)如果當(dāng)前內(nèi)存段后面有需要的內(nèi)存空間,則直接擴(kuò)展這段內(nèi)存空間,realloc()將返回原指針。
2)如果當(dāng)前內(nèi)存段后面的空閑字節(jié)不夠,那么就使用堆中的第一個能夠滿足這一要求的內(nèi)存塊,將目前的數(shù)據(jù)復(fù)制到新的位置,并將原來的數(shù)據(jù)塊釋放掉,返回新的內(nèi)存塊位置。
3)如果申請失敗,將返回NULL,此時,原來的指針仍然有效。
注意:如果調(diào)用成功,不管當(dāng)前內(nèi)存段后面的空閑空間是否滿足要求,都會釋放掉原來的指針,重新返回一個指針,雖然返回的指針有可能和原來的指針一樣,即不能再次釋放掉原來的指針。
看一下示例代碼
#include"stdio.h" #include"malloc.h"int main(){int *p1,*p2 = NULL;int n;p1 = (int *)malloc(5 * sizeof(int)); // 分配內(nèi)存p2 = p1;for(int i=0;i<5;i++)*p2++ = i;printf("分配新內(nèi)存之前:%u\n",p1);printf("再分配新的內(nèi)存:\n");scanf("%d",&n); p1 = (int *)realloc(p1, n*sizeof(int));if(p1 == NULL)printf("分配內(nèi)存失敗\n");p2 = p1;printf("分配新內(nèi)存之后:%u",p1);return 0; }
如果當(dāng)前內(nèi)存段后有足夠的空間,realloc()返回原來的指針:
分配新內(nèi)存之前:4815344
再分配新的內(nèi)存:
99
分配新內(nèi)存之后:4815344
--------------------------------
如果當(dāng)前內(nèi)存段后沒有足夠的空間,realloc()返回一個新的內(nèi)存段的指針:
分配新內(nèi)存之前:3308016
再分配新的內(nèi)存:
1000
分配新內(nèi)存之后:7763488
--------------------------------
總結(jié)
以上是生活随笔為你收集整理的c: realloc()函数解析的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 汇编: 在代码中安排自己定义的数据,栈空
- 下一篇: 汇编: 更灵活的定位内存地址的方法