Pergunta sobre android – NotSerializableException ao pressionar o botão home

9

eu tenho umActivity em que eu tenho uma classe privada de dados. NoonSaveInstanceState método, eu tento salvar isso uma instância deData. Esta é toda a minha atividade:

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

Agora, quando mudo a orientação do dispositivo, oData objeto é salvo e lido como deveria. No entanto, quando pressiono o botão home, o aplicativo trava com o seguinte no logcat:

05-10 20: 05: 51.895: E / AndroidRuntime (30317): EXCEÇÃO FATAL: principal 05-10 20: 05: 51.895: E / AndroidRuntime (30317): java.lang.RuntimeException: Parcelável encontrado IOException escrevendo objeto serializável (nome = com.rigidbits.test.TestActivity $ Data) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): em android.os.Parcel.writeSerializable (Parcel.java:1176) 05-10 20: 05: 51.895 : E / AndroidRuntime (30317): em android.os.Parcel.writeValue (Parcel.java:1130) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): em android.os.Parcel.writeMapInternal (Parcel. java: 488) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): em android.os.Bundle.writeToParcel (Bundle.java:1552) 05-10 20: 05: 51.895: E / AndroidRuntime (30317) : em android.os.Parcel.writeBundle (Parcel.java:502) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): em android.app.ActivityManagerProxy.activityPaused (ActivityManagerNative.java:1615) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): em android.app.ActivityThread.handlePauseActivity (ActivityThread.java:2298) 05-10 20:05 : 51.895: E / AndroidRuntime (30317): em android.app.ActivityThread.access $ 1700 (ActivityThread.java:117) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): em android.app.ActivityThread $ H .handleMessage (ActivityThread.java:938) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): em android.os.Handler.dispatchMessage (Handler.java:99) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): em android.os.Looper.loop (Looper.java:130) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): em android.app.ActivityThread.main (ActivityThread.java: 3683) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): em java.lang.reflect.Method.invokeNative (método nativo) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): em java .lang.reflect.Method.invoke (Method.java:507) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): em com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run (ZygoteInit.java: 862) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): em com.android.internal.os.ZygoteInit.main (ZygoteInit.java:620) 05-10 20: 05: 51.895: E / AndroidRuntime ( 30317): na dalvik .system.NativeStart.main (Método nativo) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): Causado por: java.io.NotSerializableException: com.rigidbits.test.TestActivity 05-10 20: 05: 51.895 : E / AndroidRuntime (30317): em java.io.ObjectOutputStream.writeNewObject (ObjectOutputStream.java:1535) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): em java.io.ObjectOutputStream.writeObjectInternal (ObjectOutputStream. java: 1847) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): em java.io.ObjectOutputStream.writeObject (ObjectOutputStream.java:1689) 05-10 20: 05: 51.895: E / AndroidRuntime (30317) : em java.io.ObjectOutputStream.writeObject (ObjectOutputStream.java:1653) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): em java.io.ObjectOutputStream.writeFieldValues ​​(ObjectOutputStream.java:1143) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): em java.io.ObjectOutputStream.defaultWriteObject (ObjectOutputStream.java:413) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): em java.io.ObjectOutputStream .writeHierarchy (ObjectOutputStream.java: 1241) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): em java.io.ObjectOutputStream.writeNewObject (ObjectOutputStream.java:1575) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): em java.io.ObjectOutputStream.writeObjectInternal (ObjectOutputStream.java:1847) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): em java.io.ObjectOutputStream.writeObject (ObjectOutputStream.java:1689) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): em java.io.ObjectOutputStream.writeObject (ObjectOutputStream.java:1653) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): em android.os.Parcel.writeSerializable (Parcel.java:1171) 05-10 20: 05: 51.895: E / AndroidRuntime (30317): ... mais 16

Quando eu comentar a linha noonSaveInstanceState método de modo que oData objeto énão salvo, o aplicativo desaparece corretamente.

Qualquer ajuda com isso?

apenas por interesse, faça seu UID1L em vez de um número negativo Blundell
Eu tentei, mas sem sorte. O UID é um valor gerado pelo Eclipse. nhaarman

Sua resposta

1   a resposta
22

classe interna privada.

Portanto, temacesso aos métodos e campos da sua classe externa ou seja, sua atividade.

Porque sua atividade não é serializável (e por isso não deveria ser), você está recebendo sua exceção.

Uma instância de InnerClass pode existir apenas dentro de uma instância de OuterClass e tem acesso direto aos métodos e campos de sua instância delimitadora.

Existem duas soluções.

Faça sua classe interna estática

Mova sua classe interna para ser uma classe própria e declare-a pública

Estas soluções tornam o seuData classifica uma classe por direito próprio e, em seguida, não precisa que sua instância de atividade exista

Referência:http://docs.oracle.com/javase/tutorial/java/javaOO/nested.html

Uau, resposta muito clara, e funciona! Muito obrigado! Eu fiz disso uma classe estática, porque eu tenho muitas atividades que precisam de uma classe Data, e ela possui campos exclusivos para cada uma delas. nhaarman

Perguntas relacionadas