这里写目录标题
1.为什么有动态内存分配
在讲动态内存的优势之前,先聊聊其他内存开辟方法的不足之处。
上图内存开辟方法的特点为:
1.空间开辟的大小是固定的。
2.数组在声明的时候需要指定长度,数组空间大小一旦确定 后就不能进行修改。
有时候我们需要的空间⼤⼩在程序运⾏的时候才能知
道,以上的内存开辟方法就不能满⾜了。
在这种时候就需要用到动态内存分配了,动态内存分配可以自己申请和释放空间,较为灵活。灵活的同时意味着也容易出错
2.malloc函数和free函数
动态内存开辟的函数:
向内存申请⼀块连续可⽤的空间,并返回指向这块空间的指针。
1.size指想开辟的空间大小,单位为字节。
2.如果开辟成功则返回指向这段空间的指针。
3.如果开辟失败则返回NULL指针,因此需要对malloc函数返回值进行检查。(当需要开辟的空间太大时会造成开辟失败)
4.返回值为void*,开辟空间的类型具体在使⽤的时候使⽤者⾃⼰来决定。
动态内存的释放和回收的函数:
1.如果指针p指向的空间不是动态开辟的,用free函数来释放的行为是未定义的,可能达不到想要的效果。
2.如果p 是NULL指针,则函数什么事都不做。
使用malloc和free以及下面介绍的函数都需要包含stdlib.h头文件
如果动态分配的内存没有free,程序结束后,系统会自动收回内存空间。如果程序不结束,这块空间的利用率就会减少。
3.calloc和realloc
1.函数的功能是为 num 个⼤⼩为 size 的元素开辟⼀块空 间,并且把空间的每个字节初始化为0。
2.与函数 malloc 的区别只在于 calloc 会在返回地址之前把申请的空间的每个字节初始化为全0。
如果对申请的内存空间的内容要求初始化,那么可以很⽅便的使⽤calloc函数。
申请的空间太⼩或过⼤时可以使用realloc函数调节。
1.ptr 是要调整的内存地址。
2. size 调整之后新⼤⼩。
3. 返回值为调整之后的内存起始位置。
realloc在调整内存空间的是存在两种情况:
情况1:原有空间之后有⾜够⼤的空间
情况2:原有空间之后没有⾜够⼤的空间
当是情况1 的时候,要扩展内存就原有内存之后直接追加空间,原来空间的数据不发⽣变化。
当是情况2 的时候,原有空间之后没有⾜够多的空间时,扩展的⽅法是:在堆空间上另找⼀个合适⼤⼩的连续空间来使⽤,这样函数返回的是⼀个新的内存地址。
这篇文章讲述了内存管理相关的函数,在下篇文章中我将会讲述常⻅的动态内存的错误,欢迎大家阅读!