Android内存泄漏--imageloader?

讲个故事,那天发现一个问题,在segmentfault上搜到一个提问:

有没有人用android做过类似的事情,其中一个activity里面一有一百多张图片,如果反复进入该activity就会导致溢出。
已经测试过
universal-imageloaderpicassofresco工具,都不理想,或者是我使用方法的问题。求大神指点!!

我就提问给楼主:

兄弟我最近也遇到这个问题了,也是试过universal-imageloader,picasso,fresco,请问你是怎么解决的

楼主回:
android:largeHeap="true" .....这个问题的水很深,谷歌的解决方案都不会完全没有内存泄漏的问题。

刚开始时候我怀疑是系统的问题,然后网上开始搜,发现遇到这个问题的人并不多,我猜可能是因为他们图片加载比较少。楼主给的方案我早就知道了,一看就不行,只是分配的内存多了一点而已。却发现了内存泄漏,然后怀疑是图片缓存的问题,因为这几个图片加载工具都是支持图片缓存的,于是开始搜imageloader内存泄漏,发现了《使用AndroidStudio分析和解决ImageLoader引起内存泄露问题》这篇文章。

我当时以为我找到了答案,说的很有道理,也真的有用。就是把imageloader加载后生成的bitmap给手动回收掉。
我当时回楼主:

兄弟你悲观了,我找到了一个好办法,就是昨天晚上,universal-imageloader,picasso,包括Fresco,发现他们都是存在内存泄漏,但是可以改,universal-imageloader改了以后就可以了,http://blog.csdn.net/editor19...,找了一个晚上找到的,可以用,其中会有小问题,根据下面的评论和回答就可以搞定

然后楼主把我的答案设置为最佳,但是我发现这个方法相当于把图片加载工具的优点抹杀了,最骚的是
当其他页面尝试使用imageloader加载同样的图片就会发生如下问题,而且并不好解决:

Canvas: trying to use a recycled bitmap android.graphics.Bitmap

我就自己去搞,最终找到一个方法,但是也开始怀疑其他问题,因为在找答案的时候搜到很多内存泄漏的问题,而且图片加载工具肯定很成熟的,怎么可能有这种问题,我就回了楼主:

*再告诉你我的解决方案吧,首先我们之前都是怀疑图片工具的锅,其实我怀疑可能不是,当然我还没有确定,等一下测一下,可能是我们自己的原因导致的内存泄露,导致那个我们重复进去Activity没有被回收,原因是里面一东西没有回收,比如Context,或者Thread,我们用adpter时候最好传getApplication进去,因为我一直在优化,没时间去确认到底是哪里的问题,我现在解决方案,是那个要加载图片的Activity,用ImageLoad来加载,退出的时候之前那个方法回收bitmap,这个Activity以外可能有和这个Activity重复的图片,这样如果外面再用IamageLoad加载图片 ,你程序会崩掉,说你在使用一个已回收的bitmap,所以这时候,这个Activity以外有重复图片的Activity,用Picasso或者其他图片加载工具,这样解决了。这个方法看起来不专业,但能行。但是最重要的是可能我们两个都傻逼了,可能是我们自己的问题导致Activity没有被回收导致的内存泄露,我等一下测一下。我前两天被这个问题折磨,网上找了很久,自己也搞了很久才搞定,只是希望可以帮到更多的人

然后我开始去测试,去掉了之前那个手动回收的方法,发现真的没问题。搞了半天是因为自己因为线程里面传入了当前Activity的Context对象导致销毁Activity的时候线程还没有关,那么将导致Activity的内存资源无法回收,造成内存泄漏。

所以说,大家都没有问题那肯定是自己的问题,这么成熟的框架,不会犯这些错误。我发现imageloader是可以自己回收内存的,缓存达到一个值以后就释放了之前的缓存了。

关于Context:

Context的生命周期是一个Activiy,而ApplicationContext的生命周期是整个程序。我们最要注意的就是Context的内存泄露。在Activiy的UI中要使用Context,而在其他的地方比如数据库、网络、系统服务的需要频繁调用Context的情况时,要使用ApplicationContext,以防止内存泄露。

Android内存泄漏相关文章:http://www.jianshu.com/p/c59c199ca9fa

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,530评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 86,403评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,120评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,770评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,758评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,649评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,021评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,675评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,931评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,659评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,751评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,410评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,004评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,969评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,042评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,493评论 2 343

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,432评论 25 707
  • Android 内存泄漏总结 内存管理的目的就是让我们在开发中怎么有效的避免我们的应用出现内存泄漏的问题。内存泄漏...
    _痞子阅读 1,622评论 0 8
  • 内存管理的目的就是让我们在开发中怎么有效的避免我们的应用出现内存泄漏的问题。内存泄漏大家都不陌生了,简单粗俗的讲,...
    宇宙只有巴掌大阅读 2,360评论 0 12
  • Android 内存泄漏总结 内存管理的目的就是让我们在开发中怎么有效的避免我们的应用出现内存泄漏的问题。内存泄漏...
    apkcore阅读 1,216评论 2 7
  • 最近纷纷开启学霸模式,每天早上背说文解字部首,熟读孔子家语,学习金刚拳。下午太极二十六式和太极单剑再学个七...
    272905a87a1c阅读 442评论 0 0