- 做大文件下载的时候,明明加入了@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()方法也不会执行。