C的realloc的動態分配擴展和縮小內存


#include <stdio.h>
#include <stdlib.h>

void out(int *p, int n){
	int i;
	for(i=0;i<n;i++){
		printf("%d ", *(p+i));
	}
	printf("\n-------------------\n");
}
int main(void){
	printf("請輸入要申請幾塊整型為4字節大小的塊內存:");
	int n;
	scanf("%d",&n);
	//向系統申請一個大小為n*4個字節的內存塊
	//int *p = (int*)malloc(n*sizeof(int));//未初始化
	int *p = (int*)calloc(n,sizeof(int));//初始化
	if(p!=NULL){
		out(p,n);
		int i=0;
		//初始化數據
		for(;i<n;i++){
			*(p+i) = i*i;
		}
		out(p,n);
		//擴展該p指向的內存塊存放多余數據
		size_t new_size = (n+1)*sizeof(int);
		p = (int*)realloc(p,new_size);//不會為新擴展出的內存進行初始
		if(p!=NULL){
		     printf("元素1:%d 倒數第二個元素:%d 最后一個元素:%d\n",*p,*(p+4), *(p+5));
		     //填充最后一個元素的值
		    *p = 20;
		      *(p+n) = 789;
		     printf("元素1:%d 倒數第二個元素:%d 最后一個元素:%d\n",*p,*(p+n-1), *(p+n));

		}
		printf("free釋放前的p的地址:%p *(p+n)的值:%d\n",p, *(p+n));
		//釋放p指向的這塊內存
		free(p);//p釋放后是野指針 通常把p賦值為空 p = NULL;
		//打印釋放后的指針 地址存在;還可以使用改地址完全可以訪問該地址的數據;
		//只是系統釋放了這塊內存;而地址並沒有改變;所有數據還存在
		printf("\n----------free后,該內存給其他進程繼續訪問該p執行的內存塊數據------------\n p地址:%p p指針指向的數據元素:%d\n",p, *(p+n));//程序依然會打印出p地址;和*(p+4)=789 
		
	}
	return 0;
}

  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM