内存泄漏是什么?程序员与别的专业有所不同,其他专业都是越老越香,而程序员却是一个例外,因为计算机技术更新太快,而且工作强度很大,因此大部分程序员只会写 3 年代码。3 年后要不晋升做项目经理,要么转行,个别研究所除外。
内存泄漏即 ML (Memory Leak)
指 程序在申请内存后,当该内存不需再使用 但 却无法被释放 & 归还给 程序的现象
内存泄漏的原因归根到底就是当需要被回收变量的内存被其他变量引用持有,导致内存回收失败
常见的原因有:
1.非静态内部类/匿名类原因1:非静态内部类/匿名类 Handler
持有外部的Activity/Fragment
对象的引用,导致Activity/Fragemnt
被销毁的时候没有被回收
解决方案:
将Handler类改为静态内部类 + 弱引用(WeakReference
)持有Activity
引用(静态类默认不持有外部的引用)当外部类(一般是Activity/Fragment
)结束生命周期时,清空Handler队列 原因2:非静态内部类的实例(对象)
= 静态实例
(其生命周期 = 应用的生命周期)
解决方案:
将该类改为静态类(静态类默认不持有外部的引用)将该类抽出来封装成为一个单例原因3:多线程 工作线程正在处理任务时外部类需要销毁,此时工作线程持有外部类的引用导致无法被回收
解决方案:
将该线程类类改为静态类(静态类默认不持有外部的引用)当外部类结束生命周期时强制结束线程 2.集合类原因:集合类添加元素之后持有集合元素的引用,导致该集合元素不可被回收,导致内存泄漏
解决方案:
集合类使用完元素对象后,必须将该元素从集合中删除(由于一个集合中有多个元素,所以最简单的方案就是清空集合对象(clean)&设置为Null) 3.资源对象使用后未关闭原因:资源对象使用后未关闭,在Activity/Fragemnt销毁时没有关闭/注销这些资源,将导致无法回收 例如:广播BraodcastReceiver
、文件流Fire
、图片资源Bitmap
、数据库游标
等
解决方案:
Activity
销毁时及时关闭/注销资源 4.Static关键字修饰成员变量 原因:Static关键字修饰成员变量的生命周期 = 应用的生命周期 例如 private static Context mContext = context
那么context上下文对应的Activity
则无法被回收
解决方案:
尽量不要使用Static成员变量引用,使用弱引用代替强引用使用单例模式 4.其他使用原因1:Context:当拥有Activity context
的引用的对象仍在使用,则该Activity
需要销毁时无法回收
解决方案:
对context
的引用不要超过它的生命周期使用ApplicationContext
代替 原因2:WebVIEw:不再使用WebVIEw对象后没有及时销毁,导致内存占用
解决方案:
通过多线程对不再使用的WebVIEw
对象进行销毁 原因3:Adapter:滑动ListVIEw、RecycleVIEw获取新VIEw时 都在getVIEw()中重新实例化一个VIEw对象,浪费资源,使内存占用越来越大
解决方案:
使用缓存的convertVIEw
直接使用VIEwHolder
最后赠送大家一套完整的AndroID学习资料吧。
以前一直是自己在网上东平西凑的找,找到的东西也是零零散散,很多时候都是看着看着就没了,时间浪费了,问题却还没得到解决,很让人抓狂。
后面我就自己整理了一套资料,还别说,真香!
资料有条理,有系统,还很全面,我不方便直接放出来,大家可以先看看有没有用得到的地方吧。
附上白嫖地址:《Android架构视频+BATJ面试专题PDF+学习笔记》
10200729579)]
[外链图片转存中…(img-Mmu5emmA-1610200729582)]
[外链图片转存中…(img-WMQBtYJB-1610200729584)]
总结以上是内存溢出为你收集整理的企业级项目实战讲解!Android开发经验的有效总结,不吃透都对不起自己全部内容,希望文章能够帮你解决企业级项目实战讲解!Android开发经验的有效总结,不吃透都对不起自己所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)