Я получаю данные с сервера в формате json, используя залп. Все отлично работает при подключении к Wifi. Но когда пользователь подключен к мобильным данным, особенно если подключение к мобильным данным медленное, вызывается метод OnErrorResponse. Я поместил сообщение Toast в методе OnErrorResponse. В некоторых устройствах это всплывающее сообщение вылетает с 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)