我正在使用凌空从json格式的服务器中获取数据。连接到Wifi时一切正常。但是,当用户连接到移动数据时,尤其是在移动数据连接速度较慢时,将调用OnErrorResponse方法。我已将Toast消息放入OnErrorResponse方法中。在某些设备中,此Toast消息因NullPointerException而崩溃,而在其他设备中,它运行正常。

另外,如果我等待了很长时间,但结果尚未显示,则应用程序崩溃,出现内存不足错误。请帮我。

如何有效处理这些问题?

码:

private RequestQueue songQueue = songQueue = Volley.newRequestQueue(getContext());



 private void getNewSongs() {

    JsonObjectRequest jsonObjectRequest = new JsonObjectRequest(Request.Method.GET, newSongsUrl, null, new Response.Listener<JSONObject>() {
        @SuppressLint("LongLogTag")
        @Override
        public void onResponse(JSONObject response) {

            JSONObject artistObject = null;
            String artist = "";
            String albumID = "";
            String artistID = null;

            try {


                JSONObject songListObjects = response.getJSONObject("new_song");

                    if(songListObjects.has("data")){

                        JSONObject data = songListObjects.getJSONObject("data");

                        if(data.has("song_list")) {

                            JSONArray songList = data.getJSONArray("song_list");

                            for (int i=0;i<5;i++){

                                JSONObject songListObject = songList.getJSONObject(i);

                                if (songListObject.has("mid")) {

                                    Log.e("SongListObject has", "songmid");
                                    String songID = songListObject.getString("mid");
                                    String songTitle = songListObject.getString("name");
                                    long duration = songListObject.getLong("interval") * 1000;
                                    Log.e("Title:", songTitle);
                                    Log.e("Duration:", String.valueOf(duration));

                                    JSONObject albumObject  = songListObject.getJSONObject("album");

                                    if(albumObject.has("mid")){

                                        albumID = albumObject.getString("mid");


                                    }



                                    JSONArray artistArray = songListObject.getJSONArray("singer");

                                    for (int j = 0; j < artistArray.length(); j++) {

                                        artistObject = artistArray.getJSONObject(j);

                                        if (j == 0) {

                                            if (artistObject.has("name")) {


                                                Log.e("ArtistObject: ", "has name");

                                                artist = artistObject.getString("name");
                                                artistID = artistObject.getString("mid");

                                            }
                                        } else {

                                            if (artistObject.has("name")) {

                                                Log.e("ArtistObject: ", "has name");

                                                artist = artist + " ft. " + artistObject.getString("name");

                                            }
                                        }
                                    }


                                    SongInfoModel songInfoModel = new SongInfoModel(123, songTitle,artistID, ((artist == null || (artist.length() == 0)) ? "Unknown" : artist), duration, songData, albumArtURL);
                                    SoundCloudNewSongs.add(songInfoModel);

                                    if (getView() != null){

                                        getView().findViewById(R.id.onlineProgressLoad).setVisibility(View.GONE);
                                        getView().findViewById(R.id.mainLayout).setVisibility(View.VISIBLE);

                                    }



                                }

                            }


                        }
                    }



                newSongsAdapter = new NewSongsAdapter(SoundCloudNewSongs, getContext(),listenerOnline,1);
                recyclerView_newSongs.setAdapter(newSongsAdapter);


            } catch (JSONException e) {


            }

        }
    }, new Response.ErrorListener() {
        @SuppressLint("LongLogTag")
        @Override
        public void onErrorResponse(VolleyError error) {


            if(error.getMessage()==null)
            Toast.makeText(getActivity(), "Timeout error :(", Toast.LENGTH_SHORT).show();
            else Toast.makeText(getActivity(), "Timeout error :(", Toast.LENGTH_SHORT).show();


        }
    });

    songQueue.add(jsonObjectRequest);

}


Logcat:

java.lang.NullPointerException:
  at android.widget.Toast.<init> (Toast.java:114)
  at android.widget.Toast.makeText (Toast.java:277)
  at android.widget.Toast.makeText (Toast.java:267)
  at com.musicplayer.musicana.OnlinePlaySupport$9.onErrorResponse (Unknown Source:15)
  at com.android.volley.Request.deliverError (Unknown Source:8)
  at com.android.volley.ExecutorDelivery$ResponseDeliveryRunnable.run (Unknown Source:62)
  at android.os.Handler.handleCallback (Handler.java:790)
  at android.os.Handler.dispatchMessage (Handler.java:99)
  at android.os.Looper.loop (Looper.java:164)
  at android.app.ActivityThread.main (ActivityThread.java:6518)
  at java.lang.reflect.Method.invoke (Native Method)
  at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run (RuntimeInit.java:438)
  at com.android.internal.os.ZygoteInit.main (ZygoteInit.java:807)

最佳答案

您可以定义重试次数以使成功执行为

jsonObjectRequest.setRetryPolicy(new DefaultRetryPolicy(
    1000*5,
    /*DefaultRetryPolicy.DEFAULT_MAX_RETRIES*/ 3,
    DefaultRetryPolicy.DEFAULT_BACKOFF_MULT));
songQueue.add(jsonObjectRequest);


关于NPE。 It is possible that VolleyError is null,因此您可以使用

if(error!=null && error.getMessage()==null)

10-02 03:52