问题描述
在开发App详情页时,需要展示App的截图列表,并且每个截图都自适应显示在下图红色区域:即无论图片是横向还是竖向,它都能按比例缩放显示在该区域中。 为此我们想了个方案,给图片显示区域的LinearLayout一个固定高度,然后每张图片也给了个固定高度、且宽度自适应,然后一张一张addView()进LinearLayout中,这样就能像上图那样显示。
但是,这么做带来了另外一个问题,就是在频繁打开各种App的详情页后,该应用操作越来越卡顿,打开任务管理器发现内存占用大小与打开详情页的次数成正比,直到占用过大发生OOM。
原因分析
起初怀疑是详情页面多次打开而图片没释放导致的,但是在多次狂点后使用MAT内存分析工具进行分析时,发现内存消耗Top排行为LinearLayout(约130MB),并非Bitmap。于是跟踪代码发现在这个详情Activity定义了一个内部LinearLayout专门用来动态存放详情图片,即应用详情包含几张图片就往里加多少个Child视图。
然后在关闭详情页的时候又没有释放掉该LinearLayout的子视图,导致成员变量mPictureLayout没有及时释放。
解决方案
1. 在Activity销毁时移除LinearLayout下的子视图2. 再次使用MAT分析,可以看到LinearLayout所占的内存已很小了