-1

タブの 1 つMainActivityを保持するがあり、これには 2 つのタブを持つも含まれています (また、タブも含まれています)。バンドルするデータのリストを配置する最新の - - の1 つを設定するまで、すべてがうまくいきます。他の多くのアプリを起動しているため、アプリが強制終了されています。最近開いたアプリケーションのリストから再度起動すると、ログが表示されます。TabHostCardHolderActivityTabHostActivitiesMyCardsActivitySaveOnInstanceStateoutStateNullPointerException

05-30 12:35:06.032: I/CrashLogger(28147): java.lang.RuntimeException: Unable to start activity ComponentInfo{my.package/my.package.activities.MainActivity}: java.lang.RuntimeException: Unable to start activity ComponentInfo{my.package/my.package.activities.CardsHolderActivity}: java.lang.RuntimeException: Unable to start activity ComponentInfo{my.package/my.package.activities.MyCardsActivity}: java.lang.NullPointerException
05-30 12:35:06.032: I/CrashLogger(28147): --------- Stack trace ---------
05-30 12:35:06.032: I/CrashLogger(28147):     android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2180)
05-30 12:35:06.032: I/CrashLogger(28147):     android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
05-30 12:35:06.032: I/CrashLogger(28147):     android.app.ActivityThread.access$600(ActivityThread.java:141)
05-30 12:35:06.032: I/CrashLogger(28147):     android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
05-30 12:35:06.032: I/CrashLogger(28147):     android.os.Handler.dispatchMessage(Handler.java:99)
05-30 12:35:06.032: I/CrashLogger(28147):     android.os.Looper.loop(Looper.java:137)
05-30 12:35:06.032: I/CrashLogger(28147):     android.app.ActivityThread.main(ActivityThread.java:5041)
05-30 12:35:06.032: I/CrashLogger(28147):     java.lang.reflect.Method.invokeNative(Native Method)
05-30 12:35:06.032: I/CrashLogger(28147):     java.lang.reflect.Method.invoke(Method.java:511)
05-30 12:35:06.032: I/CrashLogger(28147):     com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
05-30 12:35:06.032: I/CrashLogger(28147):     com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
05-30 12:35:06.032: I/CrashLogger(28147):     dalvik.system.NativeStart.main(Native Method)

これが私がこれを持っているコードです:

@Override
    protected void onSaveInstanceState(Bundle outState) {
        super.onSaveInstanceState(outState);
        if (cards != null)
            outState.putSerializable(EXTRA_MY_CARDS, cards);
    }

は型cardsstatic変数で、クラスは implementsです。TreeSet<Card>CardSerializable

なぜこれが起こるのか教えてもらえますか?また、killed 状態のアプリケーションを復元した後にこれが発生することに非常に驚いています。まったく問題はありませんonSaveInstanceState()。そして、私は日付も中もどちらも取得していませonRestoreInstanceState()onCreate()

4

1 に答える 1

0

カードが の場合static、なぜそれを書く必要があるのonSavedInstanceStateですか? 静的であるため、Activity インスタンスではなく Class オブジェクトに関連付けられます。

ただし、アクティビティ内で static を使用するとメモリ リークが発生するため、細心の注意を払ってください。

于 2013-05-30T10:05:15.840 に答える