Rxjava+Retrofit+OKHttp框架开发时遇到的坑(有遇到就更新)

来源:互联网 发布:excel 宏编程的语法 编辑:程序博客网 时间:2024/05/17 02:34
  • 做大文件下载的时候,明明加入了@Streaming注解,但是实际下载时发现还是把数据存到了内存里,一会就oom了,于是查了我OKHttpClient的几个拦截器代码,也没有发现什么异常。最后发现是OKhttp的Log拦截器loggingInterceptor的level设置成Body了,改成其他即可。
    @Streaming/*明明加入了Streaming注解,下载的时候还是存到了内存里??*/    @GET    Observable<ResponseBody> download(@Header("RANGE") String start, @Url String url);

解决:

    HttpLoggingInterceptor loggingInterceptor = new HttpLoggingInterceptor();    /*由于这里用了OKHttp的log拦截器,并设置了logLevel为Body,所以下载的时候log拦截器把response写到了内存里......... (⊙﹏⊙)b    loggingInterceptor.setLevel(HttpLoggingInterceptor.Level.BODY);*/    loggingInterceptor.setLevel(HttpLoggingInterceptor.Level.HEADERS);    OkHttpClient.Builder builder = new OkHttpClient.Builder();    builder.addInterceptor(loggingInterceptor);
  • 当调用Subscriber.unsubscribe()取消请求后,不能再用该subscriber去订阅observable。否则只有onstart()方法会被执行,连onError()方法也不会执行。
0 0