calloc与realloc函数---堆区分配内存

calloc与realloc函数—堆区分配内存

calloc和malloc一样都是在堆区分配内存

不同点在于 calloc 会将分配的内存初始化为0

realloc重新在堆区分配内存

如果分配的内存比原来要大,这个时候有两种情况出现

1、原有空间后序有足够大的空闲空间,那么直接在原有空间后继续开辟内存,返回原有空间的首地址
2、原有空间后序没有足够大空闲空间,重新会分配一个足够大的空间,并且将原有空间的内容拷贝到新空间下,释放原有空间,将新空间的首地址返回

测试源码

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<string.h>
#include<stdlib.h>

//calloc
void test01()
{
   //int * p = malloc(sizeof(int)* 10);

    int * p = calloc(10, sizeof(int)); //和malloc不同的地方在于 将堆区分配的内容初始化为0

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

   if (p!= NULL)
   {
	   free(p);
	   p = NULL;
   }

}

//realloc 重新在堆区分配内存
void test02()
{
	int * p =  malloc(sizeof(int)* 10);

	printf("test02............................%d\n", p);

	for (int i = 0; i < 10; i++)
	{
		p[i] = i+3;
	}
	p = realloc(p, sizeof(int)* 20);

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

	printf("%d\n", p);

	if (p!=NULL)
	{
		free(p);
		p = NULL;
	}

}



int main(){

	test01();
	test02();
	system("pause");
	return EXIT_SUCCESS;
}

测试结果

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/zxy131072/article/details/89668227
今日推荐