Pytanie w sprawie android – NotSerializableException po naciśnięciu przycisku głównego

9

mamActivity w której mam dane prywatne klasy. wonSaveInstanceState metoda, staram się zapisać to wystąpienieData. To moja cała działalność:

<code>public class TestActivity extends Activity {
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
    }

    @Override
    public void onSaveInstanceState(Bundle outState){
        outState.putSerializable("TEST", new Data());
    }

    private class Data implements Serializable {

        private static final long serialVersionUID = -4312723541994925110L;

    }
}
</code>

Teraz, gdy zmieniam orientację urządzenia,Data obiekt jest zapisywany i odczytywany tak, jak powinien. Jednak po naciśnięciu przycisku home aplikacja ulega awarii w logatcie:

05-10 20: 05: 51.895: E / AndroidRuntime (30317): FATAL EXCEPTION: główny 05-10 20: 05: 51.895: E / AndroidRuntime (30317): java.lang.RuntimeException: napotkany parcelable IOException pisanie obiektu serializowalnego (nazwa = com.rigidbits.test.TestActivity $ Data) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): na android.os.Parcel.writeSerializable (Parcel.java:1176) 05-10 20: 05: 51.895 : E / AndroidRuntime (30317): na android.os.Parcel.writeValue (Parcel.java:1130) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): na android.os.Parcel.writeMapInternal (Parcel. java: 488) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): na android.os.Bundle.writeToParcel (Bundle.java:1552) 05-10 20: 05: 51.895: E / AndroidRuntime (30317) : na android.os.Parcel.writeBundle (Parcel.java:502) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): w android.app.ActivityManagerProxy.activityPaused (ActivityManagerNative.java:1615) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): w android.app.ActivityThread.handlePauseActivity (ActivityThread.java:2298) 05-10 20:05 : 51.895: E / AndroidRuntime (30317): w android.app.ActivityThread.access 1700 $ (ActivityThread.java:117) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): w android.app.ActivityThread $ H .handleMessage (ActivityThread.java:938) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): w android.os.Handler.dispatchMessage (Handler.java:99) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): w android.os.Looper.loop (Looper.java:130) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): w android.app.ActivityThread.main (ActivityThread.java: 3683) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): w java.lang.reflect.Method.invokeNative (Metoda natywna) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): w java .lang.reflect.Method.invoke (Method.java:507) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): w com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run (ZygoteInit.java: 862) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): w com.android.internal.os.ZygoteInit.main (ZygoteInit.java:620) 05-10 20: 05: 51.895: E / AndroidRuntime ( 30317): w dalvik .system.NativeStart.main (Metoda natywna) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): Przyczyna: java.io.NotSerializableException: com.rigidbits.test.TestActivity 05-10 20: 05: 51.895 : E / AndroidRuntime (30317): w java.io.ObjectOutputStream.writeNewObject (ObjectOutputStream.java:1535) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): w java.io.ObjectOutputStream.writeObjectInternal (ObjectOutputStream. java: 1847) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): w java.io.ObjectOutputStream.writeObject (ObjectOutputStream.java:1689) 05-10 20: 05: 51.895: E / AndroidRuntime (30317) : w java.io.ObjectOutputStream.writeObject (ObjectOutputStream.java:1653) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): w java.io.ObjectOutputStream.writeFieldValues ​​(ObjectOutputStream.java:1143) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): w java.io.ObjectOutputStream.defaultWriteObject (ObjectOutputStream.java:413) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): w java.io.ObjectOutputStream .writeHierarchy (ObjectOutputStream.java: 1241) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): w java.io.ObjectOutputStream.writeNewObject (ObjectOutputStream.java:1575) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): at java.io.ObjectOutputStream.writeObjectInternal (ObjectOutputStream.java:1847) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): w java.io.ObjectOutputStream.writeObject (ObjectOutputStream.java:1689) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): w java.io.ObjectOutputStream.writeObject (ObjectOutputStream.java:1653) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): na android.os.Parcel.writeSerializable (Parcel.java:1171) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): ... 16 więcej

Kiedy komentuję linię wonSaveInstanceState metoda więcData obiekt jestnie zapisane, aplikacja znika poprawnie.

Jakaś pomoc w tym zakresie?

Próbowałem, ale nie mam szczęścia. UID to wartość generowana przez Eclipse. nhaarman
tylko dla zainteresowania zrób swój UID1L zamiast liczby ujemnej Blundell

Twoja odpowiedź

1   odpowiedź
22

Ok, wierzę, że problem polega na tym, że używaszprywatna klasa wewnętrzna.

Dlatego takdostęp do metod i pól twojej zewnętrznej klasy tj. twoja aktywność.

Ponieważ Twoja aktywność nie jest serializowana (i tak nie powinno być), masz swój wyjątek.

Instancja klasy InnerClass może istnieć tylko w instancji klasy OuterClass i ma bezpośredni dostęp do metod i pól jej otaczającej instancji.

Istnieją dwa rozwiązania.

Uczyń swoją klasę wewnętrzną statyczną

Przenieś swoją klasę wewnętrzną, aby była klasą samą w sobie i ogłos ją publicznie

Te rozwiązania sprawiają, że jesteśData klasa sama w sobie, a następnie nie potrzebuje twojej instancji aktywności, aby istnieć

Odniesienie:http://docs.oracle.com/javase/tutorial/java/javaOO/nested.html

Wow, bardzo jasna odpowiedź i działa! Wielkie dzięki! Zrobiłem to klasą statyczną, ponieważ mam sporo działań, które wymagają klasy Data i mają unikalne pola dla każdego z nich. nhaarman

Powiązane pytania