109-C言語での動的メモリの分析

C言語の動的メモリ

int a = 10;
//int arr[a];//error
int *arr = (int *)malloc(a*sizeof(int));//等同int arr[a];

Malloc、calloc、およびreallocはすべて割り当てられたメモリであり、すべてstdlib.hライブラリ内の関数ですが、いくつかの違いがあります。

malloc関数
のプロトタイプ* void malloc(unsigned int num_bytes);
num_byteは、適用されるスペースのサイズであり、int * p =(int *)malloc(20 * sizeof)のように手動で計算する必要があります。 (int))、コンパイラの場合デフォルトのintが4バイトのストレージの場合、計算結果は80バイトであり、一度に80バイトの連続スペースを適用し、スペースのベースアドレスをint型に強制して、ポインタに割り当てます。 p。現時点では、要求されたメモリ値は不明です。

calloc関数
のプロトタイプはvoid * calloc(size_t n、size_t size)です。
これは、malloc関数よりもパラメーターが1つ多く、スペースのサイズを人為的に計算する必要はありません。たとえば、20を申請する場合intタイプのスペースの場合、彼はint * p =(int *)calloc(20、sizeof(int))を実行します。これにより、人工的なスペース計算の手間が省けます。ただし、これは両者の最も重要な違いではありません。malloc適用後のスペースの値はランダムで初期化されていませんが、callocは適用後にスペースを1つずつ初期化し、値を0に設定します。

calloc関数は各スペースの値を初期化する必要があるため、mallocよりも効率が低くなります。多くの場合、スペースアプリケーションは初期値を必要としません。

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

int main()
{
    
    
	int *p = (int *)malloc(20*sizeof(int));
	int *pp = (int *)calloc(20, sizeof(int));
	int i;
	printf("malloc申请的空间值:\n\n");
	for ( i=0 ; i < 20; i++)
	{
    
    
		printf("%d ", *p++);
	}
	printf("\n\n");
	printf("calloc申请的空间的值:\n\n");
	for ( i=0 ; i < 20; i++)
	{
    
    
		printf("%d ", *pp++);
	}
	printf("\n");
	return 0;
}

ここに画像の説明を挿入
realloc関数
realloc関数は、基本的に上記の2つとは異なります。そのプロトタイプvoid * realloc(void * ptr、size_t new_Size)は
、動的メモリを拡張するために使用され、適用された動的スペースは使用するのに十分ではなく、スペース拡張操作必須)、ptr元のスペースベースアドレスへのポインタであり、new_sizeは次に展開されるサイズです。

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

int main()
{
    
    
	const int size = 2000;
	int *p = (int *)malloc(20*sizeof(int));
	int *pp = (int *)realloc(p, size*sizeof(int));
	printf("原来的p_Address:%x   扩容后的pp_Address:%x \n\n", p, pp);
	return 0;
}

ここに画像の説明を挿入
図から、拡張後のアドレスが元のアドレスと異なることがわかりますが、これは拡張メモリのサイズにのみ依存します。
注意
サイズが小さく、もともと適用ダイナミックメモリの後ろに空きメモリがある場合、システムは元のメモリ空間と、元のダイナミックな空間のベースアドレスへの復帰の真後ろに拡大していきます。サイズが大きい場合には、十分にありません拡張のために最初に適用されたスペースの後ろのスペース、システムは(20 + size)* sizeof(int)メモリの一部を再適用し、元のスペースの内容をコピーします。元のスペースは空いています。サイズが非常に大きい場合、システムメモリアプリケーションが失敗してNULLを返し、元のメモリは解放されません。注:拡張メモリスペースが元のスペースよりも小さい場合、データ損失が発生します。直接realloc(p、0);を実行すると、free(p)と同等になります。

free:動的メモリを解放します。解放しないと、メモリリークが発生します(C / C ++にとって非常に厄介な問題です)。
リークしたメモリは回復されます。1。プロセス(実行中のプログラム)が終了します。2 。 シャットダウン

以下に練習コードを貼り付けてください

int main()
{
    
    
	int n;
	scanf("%d",&n);
	int *arr = (int *)malloc(n*sizeof(int));
	int i;
	for(i=0;i<n;i++)//模拟arr被使用了
	{
    
    
		arr[i] = i;
	}
	//容量不够,需要扩容到原来的2倍
	/*
	int *brr = (int *)malloc(2*n*sizeof(int));//创建更大的内存
	for(i=0;i<n;i++)//搬新家
	{
		brr[i] = arr[i];
	}
	free(arr);//释放原来的内存
	
	arr = brr;brr = NULL;//更新新的地址//继续使用arr
	*/
	printf("%d\n",arr);
	//下面的这一句代码等同上面
	arr = (int *)realloc(arr,n/2*sizeof(int));
	printf("%d\n",arr);
	free(arr);
	return 0;
}
int main()
{
    
    
	int n;
	scanf("%d",&n);
	//申请n个长度的int数组,并将每个元素置0
	int *arr = (int *)malloc(n*sizeof(int));
	/*for(int i=0;i<n;i++)
	{
		arr[i] = 0;
	}*/
	//上面的代码和下面这一句等价
	//int *arr = (int *)calloc(n,sizeof(int));
	for(int i=0;i<n;i++)
	{
    
    
		printf("%d ",arr[i]);
	}
	//int x;
	//printf("\n%d\n",x);

	char *brr = (char *)malloc(10*sizeof(char));
	char crr[10];
	printf("%s\n%s\n",brr,crr);

	return 0;
}
//大内存
int main()
{
    
    
	//char arr[1024*1024];//1M,定义不成功
	char *arr = (char *)malloc(1024*1024*sizeof(char));
	assert(arr != NULL);
	printf("haha\n");
	return 0;
}

おすすめ

転載: blog.csdn.net/LINZEYU666/article/details/111564806