malloc和calloc和realloc的区别
malloc,calloc都是分配内存,malloc根据大小,calloc根据元素大小还有个数,malloc分配后不会初始化,calloc会自动初始化为0
realloc就是内存不够用的情况下,拓展内存,特点是:如果原来的内存后部无人使用,就直接拓展,如果有人使用,就重新分配,并且先拷贝原来内存的内容,然后回收原来的内存
calloc会自动将内存初始化为0,参数和malloc不一样,malloc 不会。
1:malloc
void main800()
{
int num;//数组的大小
scanf("%d", &num);//根据键盘初始化num的值
//动态数组,输入几个元素,就把几个元素初始化
printf("%d\n", num);
int *p = (int *)malloc(sizeof(int)*num);//动态分配内存
printf("%x\n",p);//打印地址,首地址
if (p==NULL)
{
printf("内存分配失败");
}
else{
printf("内存分配成功\n");
for (int i = 0; i < num;i++)
{
p[i] = i;//对指针指向的内存,用下标方式访问
printf("%d,%x\n",p[i],&p[i]);
}
}
free(p);//释放内存
system("pause");
}
2:calloc
void main801()
{
int num;//数组的大小
scanf("%d", &num);//根据键盘初始化num的值
//动态数组,输入几个元素,就把几个元素初始化
printf("%d\n", num);
//calloc 第一个参数多少个,第二个参数是元素占多大
int *p = (int *)calloc(num,sizeof(int));//动态分配内存
printf("%x\n", p);//打印地址,首地址
if (p == NULL)
{
printf("内存分配失败\n");
}
else{
printf("内存分配成功\n");
for (int i = 0; i < num; i++)
{
p[i] = i;//对指针指向的内存,用下标方式访问
printf("%d,%x\n", p[i], &p[i]);
}
}
free(p);//释放内存
system("pause");
}
3:realloc //17个元素,需要保留17个元素,增加6个元素,realloc,重新分配内存
//如果分配内存下面没有人用,就可以继续拓展,拓展就是在原来地址后面增加内存,如果分配内存下面有人用,就重新分配,不够的话就回收原来内存,并在回收之前分配一片内存,将原来内容拷贝过来
void main802()
{
int num,addnum;//数组的大小
scanf("%d%d", &num,&addnum);//根据键盘初始化num的值
//动态数组,输入几个元素,就把几个元素初始化
printf("%d%d\n", num,addnum);
//calloc 第一个参数多少个,第二个参数是元素占多大
int *p = (int *)malloc(sizeof(int)*num);//动态分配内存
printf("%x\n", p);//打印地址,首地址
if (p == NULL)
{
printf("内存分配失败\n");
}
else{
printf("内存分配成功\n");
for (int i = 0; i < num; i++)
{
p[i] = i;//对指针指向的内存,用下标方式访问
printf("%d,%x\n", p[i], &p[i]);
}
//重新分配内存
int *px = (int *)realloc((void *)p,sizeof(int)*(addnum+num));
for (int i = num; i < addnum + num;i++)
{
px[i] = i;
printf("%d\n",px[i]);
}
free(px);//释放内存
system("pause");
}