关于内存泄漏的一些知识概括和记录

本文详细解释了内存泄露的概念,包括内存分配的三种机制:静态、堆栈内存和堆内存,并介绍了弱引用作为解决内存泄露的一种手段。同时,文章还提供了如何通过工具和经验相结合的方式找出内存泄露的具体方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

什么是内存泄露:当一个对象已经不需要使用了,本该被回收时,而有另外一个正在使用的对象还持有它,因此就导致了对象不能被回收,这种对象被该被回收,但是却不能被回收的而留在内存中的情况被形容为内存泄漏。

内存分配的集中机制:1.静态 2.堆栈内存。静态:运行时一直存在,存放静态数据和全局的static数据。栈内存:先进后出,方法结束的时候就自动被释放掉,运算速度很快的。3:堆内存:不是连续的内存区,空间比较大,先进先出,具体讲的内存泄露就是指这个。

具体使用限制的话,首先要考虑的时weakreference的使用了,弱引用,强制回收。

那么优化的两个情况:1.主动,平时2.被动,很卡的时候  出现问题的时候。

如果我们不知道代码内存泄露的情况,如何判断我们的项目里面有哪些是有内存泄露情况的?
1.凭借工具结合自己的经验来判断。
往往我们的app在某个时候或者某个操作以后会出现很卡的现象。
1)判断就是查看内存抖动情况
Android Monitor
MAT (对Eclipse插件使用的,也有独立分析工具)
查找引用了该对象的外部对象有哪些,
然后一个一个去猜,查找可能内存泄露的嫌疑犯,依据:看(读代码和猜)他们的生命周期是否一致(可以通过快照对比),如果生命周期一致了肯定不是元凶。
排除一些容易被回收的(软引用、虚引用、弱引用)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值