什么是内存泄露、内存溢出?如何防止?

什么是内存泄露、内存溢出?如何防止?

 内存泄露内存溢出
通俗解释1、操作系统以为用户还占有某块内存, 但用户丢掉了该内存的地址, 失去对该内存的使用权;
2、调用 char *p = malloc(100), 但紧接着 p = NULL, 那么这 100 个字节将永远得不到访问, 除非程序结束, 操作系统回收内存。
1、内存不够用, 剩余的内存空间不足以满足需求;
2、企图开辟过大的空间,比如:栈对象 int num[4096][4096]是极易初始化失败的, 尤其是在线程函数中出现时。
防止方法


1、在C++中智能指针可以做到堆对象自动释放,这能有效避免内存泄露;
2、使用托管类接管堆对象(锁管理就是一个例子),避免异常中断导致灾难性的资源泄露;

3、能使用栈对象就不要使用堆对象,避免忘记释放堆对象(这个不报错,但有隐患);


1、采用即用即释放、以时间换空间的原则。(数据库内存占用较高使用频率较低时,可按照打开—访问—关闭的策略访问)
2、养成良好的资源管理习惯和意识,尽可能做到代码逻辑正确的同时,不浪费资源,不闲置资源、不过多占用资源。

 

 

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

极音战歌

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值