1

アクティビティで画像をクリックすると表示されるダイアログがあります。ダイアログが開いていて、ユーザーが画面を回転させると、LogCat に次のように表示されます。

08-23 09:47:47.151: E/WindowManager(15589): Activity my.activity.MyActivity has leaked window com.android.internal.policy.impl.PhoneWindow$DecorView@43554748 that was originally added here
08-23 09:47:47.151: E/WindowManager(15589): android.view.WindowLeaked: Activity my.activity.MyActivity has leaked window com.android.internal.policy.impl.PhoneWindow$DecorView@43554748 that was originally added here
08-23 09:47:47.151: E/WindowManager(15589):     at android.view.ViewRoot.<init>(ViewRoot.java:247)
08-23 09:47:47.151: E/WindowManager(15589):     at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:148)
08-23 09:47:47.151: E/WindowManager(15589):     at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:91)
08-23 09:47:47.151: E/WindowManager(15589):     at android.view.Window$LocalWindowManager.addView(Window.java:424)
08-23 09:47:47.151: E/WindowManager(15589):     at android.app.Dialog.show(Dialog.java:241)
08-23 09:47:47.151: E/WindowManager(15589):     at tip.machine.MyActivity$8.onClick(MyActivity.java:385)
08-23 09:47:47.151: E/WindowManager(15589):     at android.view.View.performClick(View.java:2408)
08-23 09:47:47.151: E/WindowManager(15589):     at android.view.View$PerformClick.run(View.java:8816)
08-23 09:47:47.151: E/WindowManager(15589):     at android.os.Handler.handleCallback(Handler.java:587)
08-23 09:47:47.151: E/WindowManager(15589):     at android.os.Handler.dispatchMessage(Handler.java:92)
08-23 09:47:47.151: E/WindowManager(15589):     at android.os.Looper.loop(Looper.java:123)
08-23 09:47:47.151: E/WindowManager(15589):     at android.app.ActivityThread.main(ActivityThread.java:4627)
08-23 09:47:47.151: E/WindowManager(15589):     at java.lang.reflect.Method.invokeNative(Native Method)
08-23 09:47:47.151: E/WindowManager(15589):     at java.lang.reflect.Method.invoke(Method.java:521)
08-23 09:47:47.151: E/WindowManager(15589):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:858)
08-23 09:47:47.151: E/WindowManager(15589):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
08-23 09:47:47.151: E/WindowManager(15589):     at dalvik.system.NativeStart.main(Native Method)

私がしたことはDialog dialog、 と書いてダイアログをグローバルに宣言することでしたonPause

@Override
protected void onPause() {
    System.out.println("IN PAUSE!");
    try {
        dialog.dismiss();
        System.out.println("IN TRY!");
    }
    catch   (java.lang.NullPointerException exception)  {System.out.println("IN CATCH!");}
    super.onPause();
}

dialogインスタンス化されていない場合、catch ブロックはエラーをキャッチすると思いました。とにかく、ダイアログが開いているかどうかに関係なく、回転するたびにcatchブロックのみに入ります。ダイアログを開いて回転させると、上記と同じスタック トレースが表示されます (直接 catch ブロックに移動します)。dialog.dismiss()そのため、まだWindowLeakedメッセージが表示されるのは、試みているようには見えません。

何か案は?変数の宣言/インスタンス化に何か問題があるに違いありません。ありがとう。

4

2 に答える 2

0

気にしないで、私はそれを手に入れました。問題は、同じダイアログ変数を使用する 2 つのイメージがあることです (タッチするとインスタンス化され、独自のダイアログが起動されます)。したがって、2 番目のイメージは、ダイアログを として再度宣言することで参照していましたfinal Dialog dialog ...dialogグローバル変数を作成する前は、そのようにしていました。

再宣言を削除した後、すべてが完璧です。

余談ですが、別々の時間にしか起動できない 2 つの異なるダイアログに同じダイアログ変数を使用するリスクはありますか?

于 2012-08-23T14:27:58.163 に答える