美文网首页
androidf Glide加载图片内存暴涨无法释放的优化记录

androidf Glide加载图片内存暴涨无法释放的优化记录

作者: hao_developer | 来源:发表于2021-12-01 19:41 被阅读0次

    Glide使用内存飙升
    把解决方案放到前面: 不要再ScrollView中使用Glide/Fresco加载图片,因为这两开源框架是根据RecyclerView回收池来复用图片,所以使用ScrollView会出现无法回收图片的问题

    BUG产生的原因仅仅是个简单的滑动布局,ScrollView嵌套RecycleView;

    <SmartRefreshLayout>
        <NestedScrollView>
          <LinearLayout>
                <Banner/>
                <GridView/>
                <RecyclerView/>
          </LinearLayout>
        </NestedScrollView>
    </SmartRefreshLayout>
    

    问题:大概测出的问题就是 当首页的图片加载到20左右页,图片加载了180张左右,出现卡顿问题,刷新的动画卡,Item增加的动画也卡
    初步认为是RecyclerView的notifyDataSetChanged() 数据更新的问题,

    所以我把notifyDataSetChanged()改成了notifyItemRangeInserted(),有一点效果, 但是不明显( PS: 这里还有个小细节问题,

    setHasFixedSize,貌似这个属性是这么写的,导致的问题是 下拉刷新后,再进行下拉加载更多,RecyclerView无法下拉到底部,但是下拉刷新的事件已经产生了... 把这个属性去掉就好,如果想实验可以写个Demo测试下,RecyclerView对这个属性也做了介绍,大家可以查看下源码 还是很好懂的,就不过多解释了)

    再怀疑是Glide在刷新的时候请求图片造成的卡顿,于是在RecyclerView的Scoller事件中控制滑动时暂停所有请求,运行,效果还是一样,再群里提问,还是得到一样的答案,并没有亮眼的回答

    后通过打印日志发现,在RecyclerView中的Scroll事件压根没有触发,查了下资料,由于设置了setNestedScrollingEnabled这个属性,R的滑动事件交给了Ne的NestedScrollingChildHelper,哇! 问题岂不是马上就要解决了,待我压抑一波激动地心情,跑起来吧,很明显,Glide的请求加载在滑动时已经停止,但是卡顿的问题还是没有解决…哎

    跑了趟Glide的GitHub,搜到了个类似的问题,看描述也是在加载的图片的过程中,导致内存飙升,是因为使用了CenterCrop导致...看了代码,解决办法是.format(DecodeFormat.PREFER_RGB_565),设置在Glide的option中,再run一次! 果然有效果,内存涨的果然没那么厉害了;但是每次加载还是在涨1.5M左右,并且不会下降,主动GC也没有效果...

    Fresco官方不建议这么做,相同道理,Glide也是这么设计的吧,试了下,去掉了NestedScrollViewg果然流畅了,内存保持在100上下浮动

    解决:\color{red}{不要再ScrollView中使用Glide/Fresco加载图片}\,因为这两开源框架是根据RecyclerView回收池来复用图片,所以使用ScrollView会出现无法回收图片的问题

    相关文章

      网友评论

          本文标题:androidf Glide加载图片内存暴涨无法释放的优化记录

          本文链接:https://www.haomeiwen.com/subject/qmfexrtx.html