在Dialog.show上收到错误

时间:2013-09-28 19:49:42

标签: android

我在一项活动中运行了4个后台任务。但我在一个活动中遇到错误 pDialog.show()。我无法理解。对于某些活动,我遇到了同样的问题,但我删除了进度对话框,因为这些是中等优先级,但这个我需要高优先级。这是我的错误。可以告诉我如何解决这个错误。

09-28 19:44:53.575: I/Choreographer(1120): Skipped 86 frames!  The application may be doing too much work on its main thread.
09-28 19:44:54.374: E/WindowManager(1120): Activity com.example.newairways.Gscan has leaked window com.android.internal.policy.impl.PhoneWindow$DecorView{40d40860 V.E..... R.....ID 0,0-684,192} that was originally added here
09-28 19:44:54.374: E/WindowManager(1120): android.view.WindowLeaked: Activity com.example.newairways.Gscan has leaked window com.android.internal.policy.impl.PhoneWindow$DecorView{40d40860 V.E..... R.....ID 0,0-684,192} that was originally added here
09-28 19:44:54.374: E/WindowManager(1120):  at android.view.ViewRootImpl.<init>(ViewRootImpl.java:354)
09-28 19:44:54.374: E/WindowManager(1120):  at android.view.WindowManagerGlobal.addView(WindowManagerGlobal.java:216)
09-28 19:44:54.374: E/WindowManager(1120):  at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:69)
09-28 19:44:54.374: E/WindowManager(1120):  at android.app.Dialog.show(Dialog.java:281)
09-28 19:44:54.374: E/WindowManager(1120):  at com.example.newairways.Gscan$insert.onPreExecute(Gscan.java:304)
09-28 19:44:54.374: E/WindowManager(1120):  at android.os.AsyncTask.executeOnExecutor(AsyncTask.java:586)
09-28 19:44:54.374: E/WindowManager(1120):  at android.os.AsyncTask.execute(AsyncTask.java:534)
09-28 19:44:54.374: E/WindowManager(1120):  at com.example.newairways.Gscan$1.onClick(Gscan.java:201)
09-28 19:44:54.374: E/WindowManager(1120):  at android.view.View.performClick(View.java:4204)
09-28 19:44:54.374: E/WindowManager(1120):  at android.view.View$PerformClick.run(View.java:17355)
09-28 19:44:54.374: E/WindowManager(1120):  at android.os.Handler.handleCallback(Handler.java:725)
09-28 19:44:54.374: E/WindowManager(1120):  at android.os.Handler.dispatchMessage(Handler.java:92)
09-28 19:44:54.374: E/WindowManager(1120):  at android.os.Looper.loop(Looper.java:137)
09-28 19:44:54.374: E/WindowManager(1120):  at android.app.ActivityThread.main(ActivityThread.java:5041)
09-28 19:44:54.374: E/WindowManager(1120):  at java.lang.reflect.Method.invokeNative(Native Method)
09-28 19:44:54.374: E/WindowManager(1120):  at java.lang.reflect.Method.invoke(Method.java:511)
09-28 19:44:54.374: E/WindowManager(1120):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
09-28 19:44:54.374: E/WindowManager(1120):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
09-28 19:44:54.374: E/WindowManager(1120):  at dalvik.system.NativeStart.main(Native Method)
09-28 19:44:57.234: E/Trace(1146): error opening trace file: No such file or directory (2)

2 个答案:

答案 0 :(得分:1)

如果您在程序中使用HandlerAsyncTask,请使用Thread来显示对话框。如果问题仍然存在,请尝试发布您的代码以获得进一步的帮助:)

答案 1 :(得分:0)

在退出活动之前,应关闭所有进度对话框。 您可能忘记关闭progressDialog。

在onPostExecute()方法中关闭它

    pDialog.dismiss();

查看此SO link以获取有关窗口错误的更多说明。