动态内存
为什么存在动态内存
C语言学到这里的时候,我们掌握的内存开辟有二种
int a = 10;
int arr[10] = {
0};
- 第一种是是直接在栈空间上
开辟空间
- 第二种是以数组的形式在栈空间上
开辟连续的空间
但是上面的二种方法有二个特点:
- 开辟的空间大小都是固定的,不能更改
- 数组在申明的时候,必须指定数组的长度,它所需要的内存在编译时分配
但是有时我们在程序还没运行时,不太清楚要多少空间
如果开辟的空间过小,那程序会越界
如果开辟的空间过大,那也会造成空间的浪费
这时后就会使用到动态内存函数
,因为动态内存函数
是在堆区
创建的
栈区
创建的空间大小都是固定的,是不可以更改的
动态内存函数的介绍
动态内存函数的头文件是 <stdlib.h>
melloc
melloc 函数的参数:
void* malloc(sizt_t size);
size_t size 参数,指定要开辟多少个字节的空间,是以字节为单位的
这个函数的作用是向内存申请一块空间,并返回指向这块空间的地址
- 如果开辟成功,返回的是指向这块空间的指针
- 如果开辟失败,返回的是
NULL
malloc
的返回值是void*
,所以malloc
函数并不知道要开辟什么类型的空间,所以要自行的决定- 如果
malloc
的参数size
是 0 ,这种行为是标准为定义的,最后的结果取决于编译器
malloc 函数的使用:
#include <stdlib.h> //动态内存管理对应头文件
int main()
{
// 用 malloc 开辟 40 个字节的空间,然后把空间的起始地址返回给 p
int* p = (int*)malloc(40);
//malloc申请空间可能会失败,所以要进行判断
//申请失败:打印错误信息并退出
if (p == NULL)
{
printf("%s\n", strerror(errno));
return 1;
}
int i = 0;
// 打印
for (i = 0; i < 10; i++)
{
p[i] = i;
printf("%d ", p[i]);
}
free(p); ///释放动态内存开辟的空间
p = NULL;//将p置空,防止成为野指针
return 0;
}
free
free 函数的参数:
void free(void* ptr)
free
函数是专门用来做动态内存的释放和回收的
- 如果
free
函数的参数是 ptr 指向的空间并不是动态内存函数开辟的,那free
是不能进行释放的 - 如果
free
函数是NULL
,那free
是什么都不做 free
是用于动态内存函数的释放(malloc、calloc、realloc
);
calloc
calloc 函数参数:
void* calloc(size_t num, size_t size);
calloc
第一个参数是要开辟多少空间calloc
第二个参数是开辟是什么类型的空间calloc
函数在开辟好空间后会自动把所有初始化为0
calloc 函数的使用:
calloc
和 malloc
的差别:
malloc
开辟好空间是不会初始化
的,而calloc
是开辟好空间后会自动把所有初始化为0
#include <stdlib.h>