Android 截击响应给出空点异常

Android 截击响应给出空点异常,android,nullpointerexception,android-volley,Android,Nullpointerexception,Android Volley,我尝试在我的android应用程序中使用volley库 这是我的日志 10-31 14:30:09.277: E/AndroidRuntime(22916): java.lang.NullPointerException 10-31 14:30:09.277: E/AndroidRuntime(22916): at com.mypackage.api.Api$2.onErrorResponse(Api.java:269) 10-31 14:30:09.277: E/AndroidR

我尝试在我的android应用程序中使用volley库

这是我的日志

    10-31 14:30:09.277: E/AndroidRuntime(22916): java.lang.NullPointerException
10-31 14:30:09.277: E/AndroidRuntime(22916):    at com.mypackage.api.Api$2.onErrorResponse(Api.java:269)
10-31 14:30:09.277: E/AndroidRuntime(22916):    at com.android.volley.Request.deliverError(Request.java:517)
10-31 14:30:09.277: E/AndroidRuntime(22916):    at com.android.volley.ExecutorDelivery$ResponseDeliveryRunnable.run(ExecutorDelivery.java:101)
10-31 14:30:09.277: E/AndroidRuntime(22916):    at android.os.Handler.handleCallback(Handler.java:615)
10-31 14:30:09.277: E/AndroidRuntime(22916):    at android.os.Handler.dispatchMessage(Handler.java:92)
10-31 14:30:09.277: E/AndroidRuntime(22916):    at android.os.Looper.loop(Looper.java:137)
10-31 14:30:09.277: E/AndroidRuntime(22916):    at android.app.ActivityThread.main(ActivityThread.java:4745)
10-31 14:30:09.277: E/AndroidRuntime(22916):    at java.lang.reflect.Method.invokeNative(Native Method)
10-31 14:30:09.277: E/AndroidRuntime(22916):    at java.lang.reflect.Method.invoke(Method.java:511)
10-31 14:30:09.277: E/AndroidRuntime(22916):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
10-31 14:30:09.277: E/AndroidRuntime(22916):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
10-31 14:30:09.277: E/AndroidRuntime(22916):    at dalvik.system.NativeStart.main(Native Method)
这就是我使用截击的方式

    GetStringRequest req = new GetStringRequest(Request.Method.GET,URL_API,
    new Response.Listener<String>() {
    // handle success response
    }, new Response.ErrorListener() {
    //handle error response
    @Override
public void onErrorResponse(VolleyError volleyError) {

    try {
        String error = new String(volleyError.networkResponse.data, HTTP.UTF_8);
        }
        catch (UnsupportedEncodingException e) {
            // TODO Auto-generated catch block
        e.printStackTrace();
        }
    });

我不知道怎么了,有人知道吗?

截击错误.networkResponse.data可能是空的。我不确定你想用这一行代码得到什么,但我想看看截击中的错误。你可以试试这个:

String error =  volleyError.toString();

然后,您可以检查该字符串是否存在任何特定错误[至少我是这样做的]。截击错误可能是API定义的少数错误之一,例如超时错误、连接错误、服务器错误等等。当然,如果要基于特定错误触发其他操作,可能需要进一步解析字符串

似乎只有少数设备的响应不同

onErrorResponse在少数设备上返回null(这就是崩溃的原因)

我也有同样的错误。它因设备而异…您可能会发现它在某些设备上不会给出nullpointer异常

应用此代码,希望对您有所帮助

@凌驾 公共错误响应(截击错误截击错误){


这将在日志中打印错误,该行为String error=new String(volleyError.networkResponse.data,HTTP.UTF_8);您可以尝试检查
volleyError
volleyError.networkResponse
volleyError.networkResponse.data
是否为空。我一直在这样做,但错误仍然出现哪一个变量为空?您最好学习Java。您应该通过
if(volleyError!=null)
String error =  volleyError.toString();
  new Response.ErrorListener() {
                    @Override
                    public void onErrorResponse(VolleyError error) {
                    if(error.getMessage==NULL){
  Toast.makeText(cardview.this, "Failed to retrieve data", Toast.LENGTH_LONG).show();
                    }
                else{
                        Toast.makeText(cardview.this, error.getMessage().toString(), Toast.LENGTH_LONG).show();
                    }

                });
  Log.v("VolleyError",volleyError.getMessage);

});