メモリ リークや向きの変更について多くの質問があることは承知しています。正確に何が起こっているのかを把握するために、何時間もかけて調べてテストしました。アプリをアクティビティとダイアログ フラグメントにペアリングしました。ダイアログ フラグメントは、向きが変わると消えます。私はそれを知っており、それを処理する方法を知っています。私はコードの量を最小限に抑えようとしていました。スピナーをタップして展開し、方向を変更すると、メモリ リークが発生します。展開しないと、ダイアログが消えるだけです。これで問題ありません。
スピナーを拡張すると、方向の変更時にメモリリークが発生する理由を誰でも理解できますか? 回避しなければならないのは私ですか、それともAndroidのバグですか?
ここに私のアプリコードがあります:
Manifest.xml のテスト
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.danlconsulting.testing"
android:versionCode="1"
android:versionName="1.0" >
<uses-sdk
android:minSdkVersion="8"
android:targetSdkVersion="15" />
<application >
<activity
android:name=".MainActivity"
android:label="Main" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
MainActivity.java
package com.danlconsulting.testing;
import android.os.Bundle;
import android.support.v4.app.FragmentActivity;
public class MainActivity extends FragmentActivity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
MyDialogFragment myDialog = new MyDialogFragment();
myDialog.show(getSupportFragmentManager(), "dlg");
}
}
MyDialogFragment.java
package com.danlconsulting.testing;
import android.os.Bundle;
import android.support.v4.app.DialogFragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
public class MyDialogFragment extends DialogFragment{
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
//setRetainInstance(true);
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
return inflater.inflate(R.layout.dialog_fragment,container,false);
}
}
dialog_fragment.xml
<?xml version="1.0" encoding="utf-8"?>
<ScrollView xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content" >
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:minWidth="1000dp"
android:orientation="vertical" >
<Spinner
android:id="@+id/inputSpinner"
android:layout_width="match_parent"
android:layout_height="0dip"
android:layout_weight="0.07" />
</LinearLayout>
</ScrollView>
そして activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:paddingTop="4dip"
android:paddingBottom="6dip"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:orientation="horizontal">
</LinearLayout>
編集:もちろん、同じように見える別の質問を見ました。
しかし、 android:configChanges="keyboardHidden|orientation" を追加することは望ましい解決策ではないと思いましたか??
私のLOGCAT:
11-07 14:59:34.834: E/WindowManager(14250): アクティビティ com.danlconsulting.testing.MainActivity がウィンドウ com.android.internal.policy.impl.PhoneWindow$DecorView@40531e60 をリークしました。これは最初にここに追加されました 11-07 14:59:34.834: E/WindowManager(14250): android.view.WindowLeaked: アクティビティ com.danlconsulting.testing.MainActivity が、最初にここに追加されたウィンドウ com.android.internal.policy.impl.PhoneWindow$DecorView@40531e60 をリークしました11-07 14:59:34.834: E/WindowManager(14250): android.view.ViewRoot.(ViewRoot.java:273) で 11-07 14:59:34.834: E/WindowManager(14250): android.view で.WindowManagerImpl.addView(WindowManagerImpl.java:174) 11-07 14:59:34.834: E/WindowManager(14250): android.view.WindowManagerImpl.addView(WindowManagerImpl.java:117) 11-07 14:59:34.834 : E/WindowManager(14250): android.view.Window$LocalWindowManager.addView(Window.java:424) 11-07 14:59:34.834: E/WindowManager(14250): android.app.Dialog.show(Dialog.java:241) 11-07 14:59:34.834: E/ WindowManager(14250): android.app.AlertDialog$Builder.show(AlertDialog.java:823) 11-07 14:59:34.834: E/WindowManager(14250): android.widget.Spinner.performClick(Spinner.java で:265) 11-07 14:59:34.834: E/WindowManager(14250): android.view.View$PerformClick.run(View.java:9299) 11-07 14:59:34.834: E/WindowManager(14250) ): android.os.Handler.handleCallback(Handler.java:587) 11-07 14:59:34.834: E/WindowManager(14250): android.os.Handler.dispatchMessage(Handler.java:92) 11- 07 14:59:34.834: E/WindowManager(14250): android.os.Looper.loop(Looper.java:130) 11-07 14:59:34.834: E/WindowManager(14250): android.app. ActivityThread.main (ActivityThread.java:3691) 11-07 14:59:34.834:E/WindowManager(14250): java.lang.reflect.Method.invokeNative(ネイティブ メソッド) 11-07 14:59:34.834: E/WindowManager(14250): java.lang.reflect.Method.invoke(Method. java:507) 11-07 14:59:34.834: E/WindowManager(14250): com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:912) 11-07 14:59:34.834: E/WindowManager(14250): com.android.internal.os.ZygoteInit.main(ZygoteInit.java:670) 11-07 14:59:34.834: E/WindowManager(14250): dalvik.system.NativeStart.main で(ネイティブメソッド)E/WindowManager(14250): com.android.internal.os.ZygoteInit.main(ZygoteInit.java:670) 11-07 14:59:34.834: E/WindowManager(14250): dalvik.system.NativeStart.main で(ネイティブメソッド)E/WindowManager(14250): com.android.internal.os.ZygoteInit.main(ZygoteInit.java:670) 11-07 14:59:34.834: E/WindowManager(14250): dalvik.system.NativeStart.main で(ネイティブメソッド)