Parcelableがシリアル化可能なオブジェクトgetactivity()を書き込んでいるIOExceptionを検出しました


171

だから私はこれをlogcatで取得しています:

java.lang.RuntimeException: Parcelable encountered IOException writing serializable object (name = com.resources.student_list.Student)

これは、私の生徒のクラスがシリアライズ可能ではないことを意味しますが、そうです、これが私の生徒のクラスです。

import java.io.Serializable;


public class Student implements Comparable<Student>,  Serializable{

    private static final long serialVersionUID = 1L;
    private String firstName, lastName;
    private DSLL<Grade> gradeList; 

    public Student() {
        firstName = "";
        lastName = "";
        gradeList = new DSLL<Grade>();
    }

    public String getFirstName() {
        return firstName;
    }

    public void setFirstName(String firstName) {
        this.firstName = firstName;
    }

    public String getLastName() {
        return lastName;
    }

    public void setLastName(String lastName) {
        this.lastName = lastName;
    }

    public DSLL<Grade> getGradeList() {
        return gradeList;
    }

    public void setGradeList(DSLL<Grade> gradeList) {
        this.gradeList = gradeList;
    }

    public int compareTo(Student arg0) {
        return this.lastName.compareTo(arg0.getLastName());
    }

}

これは、getIntent()メソッドを使用しているコードです。

public void onItemClick(AdapterView<?> parent, View viewClicked, int pos,
                                long id) {

                            Student clickedStudent = studentList.get(pos);
                            int position = pos;
                            Intent intent = new Intent(getActivity().getApplicationContext(), ShowStudentActivity.class);
                            Log.e("CINTENT","CREATED!!!");
                            intent.putExtra("clickedStudent",clickedStudent);
                            intent.putExtra("newStudentList",newStudentList);
                            intent.putExtra("position",position);
                            Log.e("putExtra","Passed");
                            Log.e("Start activity","passed");
                            startActivity(intent);

                        } 

                    });

これの何が悪いのかを理解するのを助けてください。

ここにLogCat全体があります:

04-17 16:12:28.890: E/AndroidRuntime(22815): FATAL EXCEPTION: main
04-17 16:12:28.890: E/AndroidRuntime(22815): java.lang.RuntimeException: Parcelable encountered IOException writing serializable object (name = com.resources.student_list.Student)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at android.os.Parcel.writeSerializable(Parcel.java:1181)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at android.os.Parcel.writeValue(Parcel.java:1135)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at android.os.Parcel.writeMapInternal(Parcel.java:493)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at android.os.Bundle.writeToParcel(Bundle.java:1612)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at android.os.Parcel.writeBundle(Parcel.java:507)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at android.content.Intent.writeToParcel(Intent.java:6111)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at android.app.ActivityManagerProxy.startActivity(ActivityManagerNative.java:1613)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at android.app.Instrumentation.execStartActivity(Instrumentation.java:1422)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at android.app.Activity.startActivityForResult(Activity.java:3191)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at android.support.v4.app.FragmentActivity.startActivityFromFragment(FragmentActivity.java:848)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at android.support.v4.app.Fragment.startActivity(Fragment.java:878)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at com.example.student_lists.MainActivity$DummySectionFragment$2.onItemClick(MainActivity.java:477)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at android.widget.AdapterView.performItemClick(AdapterView.java:292)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at android.widget.AbsListView.performItemClick(AbsListView.java:1058)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at android.widget.AbsListView$PerformClick.run(AbsListView.java:2514)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at android.widget.AbsListView$1.run(AbsListView.java:3168)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at android.os.Handler.handleCallback(Handler.java:605)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at android.os.Handler.dispatchMessage(Handler.java:92)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at android.os.Looper.loop(Looper.java:137)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at android.app.ActivityThread.main(ActivityThread.java:4447)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at java.lang.reflect.Method.invokeNative(Native Method)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at java.lang.reflect.Method.invoke(Method.java:511)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at dalvik.system.NativeStart.main(Native Method)
04-17 16:12:28.890: E/AndroidRuntime(22815): Caused by: java.io.NotSerializableException: com.resources.student_list.DSLL$DNode
04-17 16:12:28.890: E/AndroidRuntime(22815):    at java.io.ObjectOutputStream.writeNewObject(ObjectOutputStream.java:1364)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at java.io.ObjectOutputStream.writeObjectInternal(ObjectOutputStream.java:1671)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1517)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1481)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at java.io.ObjectOutputStream.writeFieldValues(ObjectOutputStream.java:979)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at java.io.ObjectOutputStream.defaultWriteObject(ObjectOutputStream.java:368)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at java.io.ObjectOutputStream.writeHierarchy(ObjectOutputStream.java:1074)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at java.io.ObjectOutputStream.writeNewObject(ObjectOutputStream.java:1404)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at java.io.ObjectOutputStream.writeObjectInternal(ObjectOutputStream.java:1671)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1517)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1481)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at java.io.ObjectOutputStream.writeFieldValues(ObjectOutputStream.java:979)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at java.io.ObjectOutputStream.defaultWriteObject(ObjectOutputStream.java:368)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at java.io.ObjectOutputStream.writeHierarchy(ObjectOutputStream.java:1074)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at java.io.ObjectOutputStream.writeNewObject(ObjectOutputStream.java:1404)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at java.io.ObjectOutputStream.writeObjectInternal(ObjectOutputStream.java:1671)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1517)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1481)
04-17 16:12:28.890: E/AndroidRuntime(22815):    at android.os.Parcel.writeSerializable(Parcel.java:1176)

LogCatを使用して、例外に関連付けられたJavaスタックトレース全体を調べます。スタックトレースがわからない場合は、ここに貼り付けてください。また、何とはDSLLGradeですか?
CommonsWare 2014

DSLL(DoubleSortedLinckedList)およびGradeは、私が作成した別のクラスであり、どちらもシリアル化可能です。
user2896762 14

LogCarスタックトレースを投稿しました
user2896762 2014

4
直接関係はありませんが、私の場合は、シリアル化できない外部クラス内で定義された内部クラスをシリアル化しようとしました。私が学んだことを非静的な内部クラスがその外部クラスへの参照が含まれている(参照この質問を)。
giraffe.guru

回答:


324
Caused by: java.io.NotSerializableException: com.resources.student_list.DSLL$DNode

あなたのDSLLクラスはDNode静的内部クラスを持っているように見え、そうでDNodeはありませんSerializable


60
@ user2896762:通常、Androidでは、スタックトレースの一番下から開始して、最後のCaused by行まで進みます。それは通常、特定の問題を指摘します。スタックトレースの他のすべてのスタンザは、トレースの下部にある「実際の」例外の周りにラップされた例外を表します。
CommonsWare 2014

3
私は原因を読んだばかりで、ほぼ3年間はこれを知りませんでした。
スターリングディアス

1
ありがとう!!! @ user2896762&@CommonsWareスタックトレースを読みました...クラスのオブジェクトの1つがシリアル化されていませんでした。そして今それは働いています。Caused by: java.io.NotSerializableException:
VJ Vishal Jogiya 2017

@CommonsWare上記のコードの使用方法。助けてくれませんか?
Jiks、

4
Modelのすべての内部クラスはシリアル化する必要があります。
Samir Mangroliya

55

OneThreadクラスはSerializableも実装する必要があります。すべてのサブクラス内部サブクラスSerializableを実装する必要があります

これは私のために働いています...


24

DNodeをシリアライズ可能にすることができない場合の適切な解決策は、変数に「一時的」を追加することです。

例:

public static transient DNode dNode = null;

Intent.putExtra(...)を使用する場合、これは変数を無視します。


2
transientJava のキーワードは、フィールドをシリアル化しないことを示すために使用されます。ここでの完全な回答:stackoverflow.com/a/910522/1306012
Bruno Bieri

8

POJOにSerializableも実装する必要がある他のモデルが含まれている場合


5

私にとってこれは、クラス内の変数を一時的なものにすることで解決しました。

前のコード:

public class UserLocation implements Serializable {
   public Location lastKnownLocation;
   public UserLocation() {}
}

後のコード

public class UserLocation implements Serializable {
    public transient Location lastKnownLocation;
    public UserLocation() {}
}   

これではうまくいきません。実際にはコードベースの他の場所にその変数の値が必要なので、一時的にすることはできません。
Taslim Oseni

これは私を助けました。ありがとう
viper

2

この問題は、カスタムクラスに他のクラスのプロパティ(「ビットマップ」など)がある場合に発生します。私が作成したのは、プロパティフィールドを「プライベートビットマップ写真」から「プライベート一時ビットマップ写真」に変更することです。ただし、レシーバーアクティビティでgetIntent()を実行すると、画像が空になります。このため、カスタムクラスをインテントに渡し、画像からバイト配列を作成して、それを個別にインテントに渡しました。

selectedItemは私のカスタムオブジェクトで、getPlacePhotoは画像を取得するための彼のメソッドです。私は以前にそれを既に設定しました、そして今私はそれを変換して別々に渡すよりも最初にそれを取得します:

 Bitmap image = selectedItem.getPlacePhoto();
 image.compress(Bitmap.CompressFormat.PNG, 100, stream);
 byte[] byteArray = stream.toByteArray();
 Intent intent = new Intent(YourPresentActivity.this, 
 TheReceiverActivity.class);
 intent.putExtra("selectedItem", selectedItem);                 
 intent.putExtra("image", byteArray);
 startActivity(intent);            

`

次に、レシーバーアクティビティで、オブジェクトと画像をバイト配列として取得し、画像をデコードして、写真のプロパティとしてオブジェクトに設定します。

 Intent intent = getIntent();
 selectedItem = (ListItem) intent.getSerializableExtra("selectedItem");
 byte[] byteArray = getIntent().getByteArrayExtra("image");
 Bitmap image = BitmapFactory.decodeByteArray(byteArray, 0, 
 byteArray.length);
 selectedItem.setPhoto(image);

2

例外は、内部クラスまたはその他の参照クラスのいずれかがシリアル化可能な実装を実装していないために発生しました。したがって、参照されるすべてのクラスがシリアライズ可能な実装を実装する必要があることを確認してください。


0

私はまた、これらのエラーを段階的に実行しており次のようなSerializableインターフェイスを実装しているmodelClassを少し変更しています

そのModelクラスでは、writeToParcel()オーバーライドメソッドを使用してParcelable インターフェースも実装します

次に、「作成者を作成するというエラーが発生したため、CREATORが作成され、引数付きで引数なしモデルクラスコンストラクターで作成されます

       @Override
        public void writeToParcel(Parcel dest, int flags) {
            dest.writeString(id);
            dest.writeString(name);
        }

        protected ArtistTrackClass(Parcel in) {
            id = in.readString();
            name = in.readString();
        }

       public ArtistTrackClass() {

        }

    public static final Creator<ArtistTrackClass> CREATOR = new Creator<ArtistTrackClass>() {
        @Override
        public ArtistTrackClass createFromParcel(Parcel in) {
            return new ArtistTrackClass(in);
        }

        @Override
        public ArtistTrackClass[] newArray(int size) {
            return new ArtistTrackClass[size];
        }
    };

ここに、

ArtistTrackClass-> ModelClass

Parcel引数を持つコンストラクターは、「属性を読み取る」であり、writeToParcel()は「属性を書き込む」です。


0

GradeクラスはSerializableも実装する必要があります

public class Grade implements Serializable {
.....your content....
}

0

すべてのarraylistをBeanクラスのSerializable wifに変更する必要があります:

public static class PremiumListBean  implements Serializable {
    private List<AddOnValueBean> AddOnValue;

    public List<AddOnValueBean> getAddOnValue() {
        return AddOnValue;
     }

    public void setAddOnValue(List<AddOnValueBean> AddOnValue) {
        this.AddOnValue = AddOnValue;
    }


    public static class AddOnValueBean  implements Serializable{

        @SerializedName("Premium")
        private String Premium;

        public String getPremium() {
            return Premium;
        }

        public void setPremium(String Premium) {
            this.Premium = Premium;
        }
    }
 }

0

同じ問題に直面しましたが、問題は静的キーワードを持つ内部クラスがいくつかあったことです。静的キーワードを削除した後、それは機能し始め、内部クラスはSerializableに実装されるはずです

問題のシナリオ

class A implements Serializable{ 
  class static B{
  } 
}

解決者

class A implements Serializable{ 
      class B implements Serializable{
      } 
    }

0

私の場合も同様に実装MainActivityする必要Serializableがありました。原因私は自分からサービスを開始する必要がありましたMainActivity

public class MainActivity extends AppCompatActivity implements Serializable {
    ...
    musicCover = new MusicCover(); // A Serializable Object
    ...
    sIntent = new Intent(MainActivity.this, MusicPlayerService.class);
    sIntent.setAction(MusicPlayerService.ACTION_INITIALIZE_COVER);
    sIntent.putExtra(MusicPlayerService.EXTRA_COVER, musicCover);
    startService(sIntent);
}
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.