Intereting Posts

NotSerializableException при нажатии кнопки «домой»

У меня есть Activity в котором у меня есть частный класс Data. В методе onSaveInstanceState я пытаюсь сохранить этот экземпляр Data . Это вся моя деятельность:

 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; } } 

Теперь, когда я изменяю ориентацию устройства, объект Data сохраняется и читается как следует. Однако, когда я нажимаю кнопку «домой», приложение ломается со следующим в logcat:

05-10 20: 05: 51.895: E / AndroidRuntime (30317): FATAL EXCEPTION: main 05-10 20: 05: 51.895: E / AndroidRuntime (30317): java.lang.RuntimeException: Parcelable столкнулся с IOException, записывающим сериализуемый объект (name = Com.rigidbits.test.TestActivity $ Data) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): at android.os.Parcel.writeSerializable (Parcel.java:1176) 05-10 20: 05: 51.895 : E / AndroidRuntime (30317): at android.os.Parcel.writeValue (Parcel.java:1130) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): at android.os.Parcel.writeMapInternal (Parcel. Java: 488) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): at android.os.Bundle.writeToParcel (Bundle.java:1552) 05-10 20: 05: 51.895: E / AndroidRuntime (30317) : At android.os.Parcel.writeBundle (Parcel.java:502) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): at android.app.ActivityManagerProxy.activityPaused (ActivityManagerNative.java:1615) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): at android.app.ActivityThread.handlePauseActivity (ActivityThread.java:2298) 05-10 20:05 : 51.895: E / AndroidRuntime (30317): at android.app.ActivityThread.access $ 1700 (ActivityThread.java:117) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): at android.app.ActivityThread $ H .handleMessage (ActivityThread.java:938) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): at android.os.Handler.dispatchMessage (Handler.java:99) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): at android.os.Looper.loop (Looper.java:130) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): at android.app.ActivityThread.main (ActivityThread.java: 3683) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): at java.lang.reflect.Method.invokeNative (собственный метод) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): в java .lang.reflect.Method.invoke (Method.java:507) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): at com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run (ZygoteInit.java: 862) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): at com.android.internal.os.ZygoteInit.main (ZygoteInit.java:620) 05-10 20: 05: 51.895: E / AndroidRuntime ( 30317): у Далвика .system.NativeStart.main (Native Method) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): вызвано: java.io.NotSerializableException: com.rigidbits.test.TestActivity 05-10 20: 05: 51.895 : E / AndroidRuntime (30317): at java.io.ObjectOutputStream.writeNewObject (ObjectOutputStream.java:1535) 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): at java.io.ObjectOutputStream.writeObject (ObjectOutputStream.java:1689) 05-10 20: 05: 51.895: E / AndroidRuntime (30317) : At java.io.ObjectOutputStream.writeObject (ObjectOutputStream.java:1653) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): at java.io.ObjectOutputStream.writeFieldValues ​​(ObjectOutputStream.java:1143) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): at java.io.ObjectOutputStream.defaultWriteObject (ObjectOutputStream.java:413) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): at java.io.ObjectOutputStream .writeHierarchy (ObjectOutputStream.java: 1241) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): at 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): at java.io.ObjectOutputStream.writeObject (ObjectOutputStream.java:1689) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): at java.io.ObjectOutputStream.writeObject (ObjectOutputStream.java:1653) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): at android.os.Parcel.writeSerializable (Parcel.java:1171) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): … еще 16

Когда я комментирую строку в методе onSaveInstanceState поэтому объект Data не сохраняется, приложение исчезает правильно.

Любая помощь в этом?

Хорошо, я считаю, что проблема в том, что вы используете частный внутренний класс .

Поэтому он имеет доступ к методам и полям вашего внешнего класса, то есть к вашей деятельности.

Поскольку ваша деятельность не является последовательной ( и поэтому ее не должно быть ), вы получаете свое исключение.

Экземпляр InnerClass может существовать только внутри экземпляра OuterClass и имеет прямой доступ к методам и полям его вмещающего экземпляра.

Введите описание изображения здесь

Есть два решения.

  • Сделайте свой внутренний класс статическим

  • Переместите свой внутренний класс в свой класс и объявите его общедоступным

Эти решения делают ваш класс Data классом сами по себе, а затем не нужно, чтобы ваш экземпляр активности существовал

Ссылка: http://docs.oracle.com/javase/tutorial/java/javaOO/nested.html