多的不说我们直接上代码,里面有讲解和注释!!!
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
//因为数组是在栈中进行开辟位置,每次函数调用完成之后就会清理空间。
//但是malloc是在堆中开辟空间,只有程序结束时才会清理。
//如果在程序结束前一直进行开辟,有可能会耗尽计算机资源。
//所以我们需要人为释放资源---- void free(void *p)
//如果我们一次使用malloc开辟的空间不够用,我们可以使用一个新的函数realloc,
//重新调整之前malloc或calloc所分配的内存大小。
//memset用来清理新开辟的内存空间
int main()
{
char *p;//定义一个野指针
p = (char *)malloc(1);//malloc(1)在堆中动态开辟一个字节
*p = 'c';//
free(p);//释放空间,p重新回到野指针
p = (char *)malloc(12);//重新为p开辟空间
if(p == NULL){//为了防止malloc失败,做一个提示
printf("malloc error\n");
exit(-1);
}
memset(p,'\0',12);//将p中的12个内存空间全部清理成\0
//strcpy(p,"yuanxiao0725");
//现在如果我们把上一句换换为---strcpy(p,"yuanxiaoyuanxiaoyuanxiao");
//此时我们会发现,开辟的内存根本不够用,运行程序会崩掉。
//为了解决这个问题我们使用realloc重新调整
printf("扩容前地址:%x\n",p);
//开始扩容
int len = strlen("yuanxiaoyuanxiaoyuanxiao");//我们计算一下新内容需要的空间大小
int newlen = len - 12 + 1;//新空间大小 - 12(原空间大小) + 1(用来存放\n) = 最终需要扩容空间大小
realloc(p,newlen);//扩容完成
printf("扩容后地址:%x\n",p);
strcpy(p,"yuanxiaoyuanxiaoyuanxiao");//将字符串拷贝至p的地址中
puts(p);//输出字符串
puts("end");
return 0;
}
结果:
扩容前地址:7d5aa0
扩容后地址:7d5aa0
yuanxiaoyuanxiaoyuanxiao
end