这个问题导致返回的数据一致报空指针,记录一下

我后来加了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 msg = Message.obtain();
                    msg.what = 1;
                    msg.obj = response.body().string();
                    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 msg = Message.obtain();
                    msg.what = 1;
                    msg.obj = json;
                    mHandler.sendMessage(msg);
                } 
            }
        });

记录下来,以后查阅

Logo

AtomGit 是由开放原子开源基金会联合 CSDN 等生态伙伴共同推出的新一代开源与人工智能协作平台。平台坚持“开放、中立、公益”的理念,把代码托管、模型共享、数据集托管、智能体开发体验和算力服务整合在一起,为开发者提供从开发、训练到部署的一站式体验。

更多推荐