![](/img/trans.png)
[英]Display alertDialog onPostExecute of AsyncTask Android
[英]Handle NPE Gracefully and Display AlertDialog in OnPostExecute / AsyncTask When Internet Connection Is Lost - Android / Java
斷開互聯網連接時,我的AsyncTask中出現了NPE(如預期的那樣)。 我試圖做一些空檢查,如果結果為空,則顯示一個alertDialog-但是,我的程序仍然崩潰,不能正常停止。 如何避免這種情況/我在代碼中缺少什么?
@Override
protected void onPostExecute(FunctionResult result) {
if (result != null) {
listener.callback(result);
}
else {
String errorMsg = "Failed";
AlertDialog.Builder builder = new AlertDialog.Builder(null);
builder.setMessage(errorMsg)
.setTitle("Error")
.setNeutralButton("OK", new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int which) {
dialog.cancel();
}
}).create().show();
}
}
05-27 17:13:11.250: E/AndroidRuntime(23343): FATAL EXCEPTION: main
05-27 17:13:11.250: E/AndroidRuntime(23343): java.lang.NullPointerException
05-27 17:13:11.250: E/AndroidRuntime(23343): at com.example.login.wstasks.WebTask.onPostExecute(WebTask.java:65)
05-27 17:13:11.250: E/AndroidRuntime(23343): at com.example.login.wstasks.WebTask.onPostExecute(WebTask.java:1)
05-27 17:13:11.250: E/AndroidRuntime(23343): at android.os.AsyncTask.finish(AsyncTask.java:631)
05-27 17:13:11.250: E/AndroidRuntime(23343): at android.os.AsyncTask.access$600(AsyncTask.java:177)
05-27 17:13:11.250: E/AndroidRuntime(23343): at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:644)
05-27 17:13:11.250: E/AndroidRuntime(23343): at android.os.Handler.dispatchMessage(Handler.java:99)
05-27 17:13:11.250: E/AndroidRuntime(23343): at android.os.Looper.loop(Looper.java:137)
05-27 17:13:11.250: E/AndroidRuntime(23343): at android.app.ActivityThread.main(ActivityThread.java:5041)
05-27 17:13:11.250: E/AndroidRuntime(23343): at java.lang.reflect.Method.invokeNative(Native Method)
05-27 17:13:11.250: E/AndroidRuntime(23343): at java.lang.reflect.Method.invoke(Method.java:511)
05-27 17:13:11.250: E/AndroidRuntime(23343): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
05-27 17:13:11.250: E/AndroidRuntime(23343): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
05-27 17:13:11.250: E/AndroidRuntime(23343): at dalvik.system.NativeStart.main(Native Method)
05-27 17:13:21.240: V/TaskManager(23343): In executeTask() on BACKGROUND THREAD
05-27 17:13:21.290: D/dalvikvm(23343): GC_CONCURRENT freed 406K, 9% free 4779K/5224K, paused 4ms+3ms, total 31ms
05-27 17:13:21.340: V/TaskManager(23343): In logTaskInfo() on BACKGROUND THREAD
05-27 17:13:21.340: V/TaskManager(23343): -------------------
05-27 17:13:21.340: V/TaskManager(23343): -------------------
更換
AlertDialog.Builder builder = new AlertDialog.Builder(null);
同
AlertDialog.Builder builder = new AlertDialog.Builder(YOUR_ACTIVITY_NAME.this);
編輯:您需要如上所述在活動本身中處理它:
protected void onPostExecute(FunctionResult result) {
listener.callback(result);
}
和
KeepAliveData data = new KeepAliveData();
FunctionResult keepAliveResponse = null;
try {
keepAliveResponse = new KeepAliveTask(variables.login, data)
.execute().get();
if (keepAliveResponse == null) {
String errorMsg = "KeepAlive Failed";
AlertDialog.Builder builder = new AlertDialog.Builder(ActivityMain.this);
builder.setMessage(errorMsg)
.setTitle("Error")
.setNeutralButton("OK", new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int which) {
dialog.cancel();
}
}).create().show();
}
} catch (Exception e) {
e.printStackTrace();
return false;
}
我不知道所提出的NPE的確切數字,但問題可能與這條數字有關:
new AlertDialog.Builder(null);
您不能在此處傳遞null。 您應該在此處放置android.content.Context的實例(例如,您的Activity發起了此任務)。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.