今天复习OkHttp源码,用最基础的请求突然遇到一个问题,Log可以打印成功有值,解析json时没有值,纳闷
private void ReChangePost() {
APIInterface apiInterface = RetrofitCreator.getInstance().getRetrofit().create(APIInterface.class);
retrofit2.Call<ResponseBody> task = apiInterface.getJson();
task.enqueue(new retrofit2.Callback<ResponseBody>() {
@Override
public void onResponse(retrofit2.Call<ResponseBody> call, retrofit2.Response<ResponseBody> response) {
if(response.code()==HttpURLConnection.HTTP_OK){
try {
// Log.i("song","Retrofit改造返回结果"+response.body().string());
String json = response.body().string();
Gson gson=new Gson();
WanBean wanBean=gson.fromJson(json,WanBean.class);
List<WanBean.DataBean> wanList = wanBean.getData();
PicAdapter picAdapter=new PicAdapter(MainActivity.this,wanList);
recyclerView.setAdapter(picAdapter);
} catch (IOException e) {
e.printStackTrace();
}
}
}
@Override
public void onFailure(retrofit2.Call<ResponseBody> call, Throwable t) {
}
});
}
注意看我调用了两次response.body().string(),原来response.body().string()只能调用一次,第二次为空。因为response.body().string()所包含的资源往往很大 ,当客户端接收到数据之后,okhttp的缓冲区就会自动释放资源!!
在实际开发中,响应主体 RessponseBody
持有的资源可能会很大,所以 OkHttp 并不会将其直接保存到内存中,只是持有数据流连接。只有当我们需要时,才会从服务器获取数据并返回。同时,考虑到应用重复读取数据的可能性很小,所以将其设计为一次性流(one-shot)
,读取后即 '关闭并释放资源'。