动态内存函数的介绍
以下函数均在<stdlib.h>头文件中
1️⃣malloc:
void* malloc (size_t size);
-
向内存申请一段连续可用的空间,返回值指向这块空间的指针
-
如果该地址不存在,那返回的是指针,所以我们需要检验返回的是不是空指针
-
返回类型是void*,所以malloc函数空间的类型需要自己来决定
-
大小指的是多少字节
2️⃣ralloc:
void* calloc (size_t num, size_t size);
-
函数是建立num个size大小的空间
-
ralloc函数建立后会把函数初始化成0
3️⃣realloc:
void* realloc (void* ptr, size_t size);
-
realloc可以灵活的调整内存的大小
-
ptr是需要调整的内存的位置,size是需要变成多大(所以size的大小需要原来的的大小加上需要增加的大小)
-
realloc在调整内存后,返回值是调整后的空间位置:有两种情况:
- 原有的空间足够放下新加的大小,直接进行存放。
- 原有的空间不够,需要新开辟空间,进行存放,返回值就是新开辟的空间的位置
4️⃣free:
在上述函数使用后,需要释放函数所占的动态内存
void free (void* ptr);
-
ptr是动态的指针,free释放的才有意义,如果不是动态的指针,那么free的行为是未定义的
-
如果ptr是空指针,则函数什么都不做
-
不能只释放一部分的空间
-
不能对同一块动态空间多次释放(可以在第一次释放后,将指针赋给空指针)
-
动态内存必须释放,保证free能每次运行的时候能运行到
-
若使用函数,函数没有释放内存,在函数接收后,同样不要忘记释放内存
访问空指针
-
在以上的函数中返回值均是指针,所以我们在使用中需要进行判断所存在的函数是否为空指针。否则会存在
#include<stdio.h> #include<stdlib.h> #include<errno.h> #include<string.h> int main() { int* p = (int*)malloc(40); if (p == NULL) { printf("%s", strerror (errno)); return 1; } free(p); return 0; }
动态内存访问过界
-
动态内存也是不能过界访问
-
需要看开辟的空间的大小
非动态开辟的空间
-
不能用free释放
-
非动态开辟的空间是在栈区(高地址向低地址访问),而以上函数是在堆区(低地址向高地址访问)开辟的空间