2016-07-18 4 views
1

Ich wollte in das Bundle ein SparseArray senden, aber da kann ich nicht eine Klasse, die SparseArray in ein Serializable-Objekt machen, aber jetzt, wenn ich meine Anwendung ausführen gibt es dies Fehlerausgabe.Parcelable IOException Schreiben serializable Objekt SparseArray <int[]>

java.lang.RuntimeException: Parcelable encountered IOException writing serializable object (name = com.awemobi.legominifigures.DataHelper) 

Die Klasse dieses Problem gibt, ist der nächste:

public class DataHelper implements Serializable { 
private SparseArray<int[]> data; 

public DataHelper(SparseArray<int[]> data) 
{ 
    this.data = data; 
} 

public SparseArray<int[]> getArray() 
{ 
    return data; 
} 

}

Ich dachte, es wegen der int sein könnte [] und ich noch eine andere Klasse Positionen gemacht int zu machen [] serialisierbar, das Problem besteht jedoch weiterhin. Was kann ich versuchen, mehr zu tun? Ich kann nicht genau verfolgen, was die Ursache des Fehlers sein könnte.

Dies ist die komplette Ausgabe:

FATAL EXCEPTION: main 
Process: com.awemobi.legominifigures, PID: 18077 
java.lang.RuntimeException: Parcelable encountered IOException writing serializable object (name = com.awemobi.legominifigures.DataHelper) 
    at android.os.Parcel.writeSerializable(Parcel.java:1388) 
    at android.os.Parcel.writeValue(Parcel.java:1335) 
    at android.os.Parcel.writeArrayMapInternal(Parcel.java:638) 
    at android.os.BaseBundle.writeToParcelInner(BaseBundle.java:1313) 
    at android.os.Bundle.writeToParcel(Bundle.java:1096) 
    at android.os.Parcel.writeBundle(Parcel.java:663) 
    at android.support.v4.app.FragmentState.writeToParcel(Fragment.java:137) 
    at android.os.Parcel.writeTypedArray(Parcel.java:1191) 
    at android.support.v4.app.FragmentManagerState.writeToParcel(FragmentManager.java:384) 
    at android.os.Parcel.writeParcelable(Parcel.java:1357) 
    at android.os.Parcel.writeValue(Parcel.java:1262) 
    at android.os.Parcel.writeArrayMapInternal(Parcel.java:638) 
    at android.os.BaseBundle.writeToParcelInner(BaseBundle.java:1313) 
    at android.os.Bundle.writeToParcel(Bundle.java:1096) 
    at android.os.Parcel.writeBundle(Parcel.java:663) 
    at android.app.ActivityManagerProxy.activityStopped(ActivityManagerNative.java:2944) 
    at android.app.ActivityThread$StopInfo.run(ActivityThread.java:3355) 
    at android.os.Handler.handleCallback(Handler.java:739) 
    at android.os.Handler.dispatchMessage(Handler.java:95) 
    at android.os.Looper.loop(Looper.java:135) 
    at android.app.ActivityThread.main(ActivityThread.java:5376) 
    at java.lang.reflect.Method.invoke(Native Method) 
    at java.lang.reflect.Method.invoke(Method.java:372) 
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:908) 
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:703) 
Caused by: java.io.NotSerializableException: android.util.SparseArray 
    at java.io.ObjectOutputStream.writeNewObject(ObjectOutputStream.java:1344) 
    at java.io.ObjectOutputStream.writeObjectInternal(ObjectOutputStream.java:1651) 
    at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1497) 
    at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1461) 
    at java.io.ObjectOutputStream.writeFieldValues(ObjectOutputStream.java:959) 
    at java.io.ObjectOutputStream.defaultWriteObject(ObjectOutputStream.java:360) 
    at java.io.ObjectOutputStream.writeHierarchy(ObjectOutputStream.java:1054) 
    at java.io.ObjectOutputStream.writeNewObject(ObjectOutputStream.java:1384) 
    at java.io.ObjectOutputStream.writeObjectInternal(ObjectOutputStream.java:1651) 
    at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1497) 
    at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1461) 
    at android.os.Parcel.writeSerializable(Parcel.java:1383) 
    at android.os.Parcel.writeValue(Parcel.java:1335)  
    at android.os.Parcel.writeArrayMapInternal(Parcel.java:638)  
    at android.os.BaseBundle.writeToParcelInner(BaseBundle.java:1313)  
    at android.os.Bundle.writeToParcel(Bundle.java:1096)  
    at android.os.Parcel.writeBundle(Parcel.java:663)  
    at android.support.v4.app.FragmentState.writeToParcel(Fragment.java:137)  
    at android.os.Parcel.writeTypedArray(Parcel.java:1191)  
    at android.support.v4.app.FragmentManagerState.writeToParcel(FragmentManager.java:384)  
    at android.os.Parcel.writeParcelable(Parcel.java:1357)  
    at android.os.Parcel.writeValue(Parcel.java:1262)  
    at android.os.Parcel.writeArrayMapInternal(Parcel.java:638)  
    at android.os.BaseBundle.writeToParcelInner(BaseBundle.java:1313)  
    at android.os.Bundle.writeToParcel(Bundle.java:1096)  
    at android.os.Parcel.writeBundle(Parcel.java:663)  
    at android.app.ActivityManagerProxy.activityStopped(ActivityManagerNative.java:2944)  
    at android.app.ActivityThread$StopInfo.run(ActivityThread.java:3355)  
    at android.os.Handler.handleCallback(Handler.java:739)  
    at android.os.Handler.dispatchMessage(Handler.java:95)  
    at android.os.Looper.loop(Looper.java:135)  
    at android.app.ActivityThread.main(ActivityThread.java:5376)  
    at java.lang.reflect.Method.invoke(Native Method)  
    at java.lang.reflect.Method.invoke(Method.java:372)  
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:908)  
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:703)  
+0

Stapelüberwachung bitte. – EJP

+0

Es tut mir wirklich leid, aber ich bin nicht sicher, was meinst du mit Stack-Trace. Kannst du mir das bitte erklären? Ich habe schon gesucht, bin mir aber immer noch nicht sicher was es ist. – Slugslinger

+1

Der Stack-Trace ist die Sache mit der Ausnahme und Fehlermeldung oben. Dies ist Java 101. – EJP

Antwort

0

Versuchen Sie, Ihre SparseArray Variable "Daten" als vorübergehende erklärt, wie diese,

private transient SparseArray<int[]> data;