动态内存
前言
若是没有动态容量,在创建变量时,只能预先设计好容量,而这样的容量可能会出现过多的浪费或者是容量不足,不能灵活的增加或减少容量。运用好关于动态内存管理的函数,就可以解决这些问题。让我们来了解这些函数吧!
一、malloc
void* malloc (size_t size);
- 该函数返回类型为空指针类型,输入的参数是无符号整数类型,是需要申请的多大的空间。
- 申请指向一块 没有初始化的
size_t size
的空间的指针,没有申请成功则会返回 NULL 指针。 - 函数是向堆区申请的内存,与所创建的临时变量存储的空间不同,它们储存在栈区。
- 当进程正常结束后,操作系统会自动将该申请的空间释放掉
- 使用:
#include<stdio.h>
#include<stdlib.h>
int main()
{
int* p = (int*)malloc(10 * sizeof(int));
if (p == NULL)
{
perror("malloc");
return;
}
for (int i = 0; i < 10; i++)
{
p[i] = i;
}
for (int j = 0; j < 10; j++)
{
printf("%d ", p[j]);
}
free(p);
p = NULL;
return 0;
}
申请成功:
申请失败则为:
二.calloc
void* calloc (size_t num, size_t size);
- 函数的返回值为空指针类型
- 第一个参数表示开辟元素的个数,第二个参数表示每个元素的大小(单位:字节)
- malloc与calloc大致相同,区别是calloc申请的空间会被初始化为0
三.realloc
void* realloc (void* ptr, size_t size);
- 函数的返回值为空指针类型
- 第一个参数为空指针类型是一块动态开辟空间的地址,第二个参数是重新调整后动态开辟空间的大小
- 使用realloc扩容时,后面的空间充足则会挨着原空间扩容,若后面的空间不够会找到一块新的空间大小为扩容后的大小,并且会将原空间的内容拷贝到新空间中,还会释放掉原空间。
后面的空间充足:
后面的空间不够:
示例:
四.free
void free (void* ptr);
- 作用是将ptr指向的动态开辟的空间释放
free(NULL)
没有问题- 在动态开辟内存空间后,并且使用完后,要及时free释放空间,避免造成内存泄漏
- free完后,最好将释放的指针指向NULL,防止非法访问