android - 进度对话框导致 "window leak"

标签 android android-alertdialog android-progressbar

我有一个名为 requestLocation 的方法,它启动一个进度对话框。我从 onResume() 调用此方法;

我的方法:

public void requestLocation() {
    try { 
        progressDialog = ProgressDialog.show(this, "", "Obtaining Location Service", true);
    }
    catch(Exception e) {

    }

    updates=0;
    startingLocal = null;
    latestLocal = null;
    gps = null;
    gps = new KNLocationService(this);
    gps.setParent(this);
    // check if GPS enabled
    if (gps.canGetLocation()) {

        double latitude = gps.getLatitude();
        double longitude = gps.getLongitude();

        //progressDialog.dismiss();
        //locationServiceText.setText("Aquiring location");

    } else {
        try { 
            progressDialog.dismiss();
        } catch (Exception e) {

        }

        locationServiceText.setText("No LocationService Provided");
    }

}

但是我收到以下错误,我假设是由于进度对话框造成的,但我似乎无法找出到底是什么导致了它..

05-28 09:50:12.615: E/WindowManager(13774): Activity com.KingNozzle.KNAugmentedRealityActivity has leaked window com.android.internal.policy.impl.PhoneWindow$DecorView@428a6f00 that was originally added here
05-28 09:50:12.615: E/WindowManager(13774): android.view.WindowLeaked: Activity com.KingNozzle.KNAugmentedRealityActivity has leaked window com.android.internal.policy.impl.PhoneWindow$DecorView@428a6f00 that was originally added here
05-28 09:50:12.615: E/WindowManager(13774):     at android.view.ViewRootImpl.<init>(ViewRootImpl.java:374)
05-28 09:50:12.615: E/WindowManager(13774):     at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:292)
05-28 09:50:12.615: E/WindowManager(13774):     at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:224)
05-28 09:50:12.615: E/WindowManager(13774):     at android.view.WindowManagerImpl$CompatModeWrapper.addView(WindowManagerImpl.java:149)
05-28 09:50:12.615: E/WindowManager(13774):     at android.view.Window$LocalWindowManager.addView(Window.java:547)
05-28 09:50:12.615: E/WindowManager(13774):     at android.app.Dialog.show(Dialog.java:277)
05-28 09:50:12.615: E/WindowManager(13774):     at android.app.ProgressDialog.show(ProgressDialog.java:116)
05-28 09:50:12.615: E/WindowManager(13774):     at android.app.ProgressDialog.show(ProgressDialog.java:99)
05-28 09:50:12.615: E/WindowManager(13774):     at com.KingNozzle.KNAugmentedRealityActivity.requestLocation(KNAugmentedRealityActivity.java:494)
05-28 09:50:12.615: E/WindowManager(13774):     at com.KingNozzle.KNAugmentedRealityActivity.onResume(KNAugmentedRealityActivity.java:162)
05-28 09:50:12.615: E/WindowManager(13774):     at android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1184)
05-28 09:50:12.615: E/WindowManager(13774):     at android.app.Activity.performResume(Activity.java:5082)
05-28 09:50:12.615: E/WindowManager(13774):     at android.app.ActivityThread.performResumeActivity(ActivityThread.java:2565)
05-28 09:50:12.615: E/WindowManager(13774):     at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:2603)
05-28 09:50:12.615: E/WindowManager(13774):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2089)
05-28 09:50:12.615: E/WindowManager(13774):     at android.app.ActivityThread.access$600(ActivityThread.java:130)
05-28 09:50:12.615: E/WindowManager(13774):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1195)
05-28 09:50:12.615: E/WindowManager(13774):     at android.os.Handler.dispatchMessage(Handler.java:99)
05-28 09:50:12.615: E/WindowManager(13774):     at android.os.Looper.loop(Looper.java:137)
05-28 09:50:12.615: E/WindowManager(13774):     at android.app.ActivityThread.main(ActivityThread.java:4745)
05-28 09:50:12.615: E/WindowManager(13774):     at java.lang.reflect.Method.invokeNative(Native Method)
05-28 09:50:12.615: E/WindowManager(13774):     at java.lang.reflect.Method.invoke(Method.java:511)
05-28 09:50:12.615: E/WindowManager(13774):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
05-28 09:50:12.615: E/WindowManager(13774):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
05-28 09:50:12.615: E/WindowManager(13774):     at dalvik.system.NativeStart.main(Native Method)

我似乎没有使应用程序崩溃,但我仍然想纠正这个问题。

最佳答案

您必须关闭对话框:

@Override
protected void onDestroy() {
    super.onDestroy();
    progressDialog.dismiss();
}

关于android - 进度对话框导致 "window leak",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16793857/

相关文章:

java - 在 fragment 中创建 android 对话框而不是直接由 Activity 创建的原因是什么?

android - 无法解析符号(上下文)

java - 使用 AsyncTask 显示圆形进度条

android - 自定义全息样式进度条

java - runOnUiThread 方法和 Handler 有什么区别?哪一个最好用?

android - Room getItemById 查询不适用于 LiveData

android - 从 DatePickerDialog 中删除标题

android - 从网上获取一个.txt,对比一下,在一个AsyncTask中打开一个dialog

android - 进度条在省电模式下消失(Android 5.x)?

android - 在后台访问 Google Drive Android API