OkHttp使用HttpLoggingInterceptor的坑:下载文件请求阶段需要等很久以及OOM

最近使用到了OkHttp,准确的说是retrofit,毕竟retrofit是okhttp的封装,但是实际上问题是处在okhttp上面

使用HttpLoggingInterceptor去打印请求和响应日志,使用了level = Body

正常请求没什么问题,但是当我使用这个okhttp实例去下载文件的时候出现了问题,请求很久才能拿到正文开始下载

开始我以为是链接的问题,换了之后发现还是这样,经过一番定位(一行行注释),把问题定位到了HttpLoggingInterceptor拦截器上,发现添加了这个拦截器,并且把level设置为Body的时候就会出现这种情况(由于android不允许在主线程请求网络,所以UI没卡),之后经过调试,发现当代码走到以下位置时,就会卡住

大致原因应该是这里需要将内容全部请求出来,然后方面后面的复制buffer(为什么要复制,其他文章会写)

然而在你下载东西的时候,内容是很多的,那么这里的卡住的时长和文件大小成正比,如果文件太大,内存不够,那么系统会不停地GC去获取更多内存,但是总内存就那么点大,所以这就是个死结,甚至会OOM

当然,这里设置level < Body就好了,但是有些时候会有特殊需求,比如说新加一个拦截器,需要根据服务端返回的数据做不同的处理,这里就要参照HttpLoggingInterceptor自定义一个拦截器,buffer复制的地方必定会经过,那么上面的问题就会出现

解决办法

就是定义两个okhttp(retrofit也是两个)实例,一个专门用来下载文件,不加这个拦截器,并且HttpLoggingInterceptor的level < Body就好了,另外一个专门添加这个拦截器去处理服务器返回数据

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值