这个问题导致返回的数据一致报空指针,记录一下
我后来加了Log.d
比如这样写:那么只有在第一次Log.d那行,才能得到response.body().string()数据
而下面的if中和msg.obj都得不到,所以导致最后在handlerMessage中报空指针异常
public void onResponse(okhttp3.Call call, okhttp3.Response response) throws IOException { Log.d("Json数据",response.body().string()); if(response.body().string().indexOf("Success") != -1) { mACache.put(param, response.body().string(), ACache.TIME_DAY); //将得到的信息放到Message中发送 Message msg = Message.obtain(); // 消息标识 msg.what = 1; // 消息内存存放 msg.obj = response.body().string(); // 在工作线程中 通过Handler发送消息到消息队列中 mHandler.sendMessage(msg); } } });
正确的写法就是第一次把他赋给json,得到这个值,就用json,然后这样response.body().string()就只用了一次
public void onResponse(okhttp3.Call call, okhttp3.Response response) throws IOException { String json = response.body().string(); Log.d("Json数据",json); if(json.indexOf("Success") != -1) { mACache.put(param, response.body().string(), ACache.TIME_DAY); //将得到的信息放到Message中发送 Message msg = Message.obtain(); // 消息标识 msg.what = 1; // 消息内存存放 msg.obj = json; // 在工作线程中 通过Handler发送消息到消息队列中 mHandler.sendMessage(msg); } } });记录下来,以后查阅