アクティビティで画像をクリックすると表示されるダイアログがあります。ダイアログが開いていて、ユーザーが画面を回転させると、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
メッセージが表示されるのは、試みているようには見えません。
何か案は?変数の宣言/インスタンス化に何か問題があるに違いありません。ありがとう。