动态内存管理

目录

前言

一、动态内存函数

二、常见的动态内存错误

三、练习题


前言

由于开辟静态内存,我们无法确定会使用多少,就会浪费许多空间,比如int arr[1000],我们只使用30个元素的空间,就会造成970个元素空间的浪费

一、动态内存函数

动态内存开辟:malloc、calloc、realloc(增容)

动态内存释放:free

malloc

只有一个参数,是想开辟连续可用的空间的大小(单位:byte),返回类型是void*,返回开辟的空间的起始地址,但不会进行初始化

注意:使用malloc函数时要进行判断返回的起始地址是否为NULL,因为开辟空间可能会失败,这时就会返回NULL,比如开辟的空间过大时

calloc

有两个参数,第一个参数是想要开辟的元素的个数的连续可用空间,第二个参数是想要开辟的单个元素所占用的空间,返回类型是void*,返回开辟的空间的起始地址,会将其开辟空间的每一个字节都初始化为全0

注意:使用calloc函数时要进行判断返回的起始地址是否为NULL,因为开辟空间可能会失败,这时就会返回NULL,比如开辟的空间过大时

realloc(增容)

有两个参数,第一个参数是原来空间的起始地址,第二个参数是想要开辟空间的总大小(单位:byte),返回类型是void*,返回原来空间的起始地址或者把原来空间的数据拷贝到新空间,再返回新空间的起始地址

注意:使用realloc函数时要进行判断返回的起始地址是否为NULL,因为增容开辟空间可能会失败,这时就会返回NULL,比如开辟的空间过大时


增容的两种情形

原空间后面有足够的空间

原空间后面没有足够的空间

free

只有一个参数,是将要被释放空间的起始地址(指针),返回类型是void

注意:对于用动态内存函数开辟的空间一定要用free释放,否则会出现内存泄露

如果参数ptr指向的空间不是动态开辟的,那free函数的行为是未定义的,所以用free释放后,需将其指针置为NULL,否则容易出现野指针问题

如果参数ptr是NULL指针,则函数什么事都不做

 

二、常见的动态内存错误

对空指针解引用操作

对动态开辟空间的越界访问

对非动态开辟内存使用free释放

使用free释放一块动态开辟内存的一部分 

 free()只能释放全部空间,也就说参数只能是开辟空间的起始地址

 对同一块动态内存多次释放

所以free释放空间后,一定要将其中的指针置为NULL,就能避免上图的错误

动态开辟内存忘记释放(内存泄漏)

  

 三、练习题

 

改进后:

 

  • 7
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值