พบพัสดุที่ IOException กำลังเขียน getactivity วัตถุต่อเนื่อง ()


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 ทั้งหมดที่เกี่ยวข้องกับข้อยกเว้นของคุณ หากคุณไม่เข้าใจการติดตามสแต็กวางที่นี่ นอกจากนี้สิ่งที่DSLLและสิ่งที่เป็นGrade?
CommonsWare

DSLL (DoubleSortedLinckedList) และ Grade อีกคลาสหนึ่งที่สร้างโดยฉันทั้งคู่เป็นแบบอนุกรม
2896762

ฉันโพสต์ร่องรอยการติดตามสแต็คของ
LogCar

4
ไม่เกี่ยวข้องโดยตรง แต่ ... ในกรณีของฉันฉันพยายามที่จะทำให้เป็นอนุกรมชั้นในที่กำหนดไว้ในชั้นนอกที่ไม่ต่อเนื่อง ฉันเรียนรู้ว่าคลาสภายในที่ไม่คงที่มีการอ้างอิงถึงคลาสภายนอกของพวกเขา (ดูคำถามนี้ )
giraffe.guru

คำตอบ:


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

คุณDSLLระดับดูเหมือนจะมีDNodeระดับชั้นคงที่และไม่ได้เป็นDNodeSerializable


60
@ user2896762: โดยทั่วไปบน Android ให้เริ่มจากด้านล่างของการติดตามสแต็กและทำงานจนถึงCaused byบรรทัดสุดท้าย นั่นมักจะชี้ไปที่ปัญหาเฉพาะ บทอื่น ๆ ของการติดตามสแต็กแสดงถึงข้อยกเว้นที่ล้อมรอบข้อยกเว้น "ของจริง" ที่ด้านล่างของการติดตาม
CommonsWare

3
ฉันเพิ่งอ่านสาเหตุที่เกิดขึ้นไม่ทราบมานานเกือบ 3 ปีแล้ว
สเตอร์ลิง Diaz

1
ขอบคุณ !!! @ user2896762 & @CommonsWare ฉันอ่านการติดตามสแต็ก ... พบหนึ่งในวัตถุในชั้นเรียนของฉันไม่ได้ต่อเนื่องกัน และตอนนี้มันทำงานอยู่ Caused by: java.io.NotSerializableException:
VJ Vishal Jogiya

@CommonsWare วิธีการใช้รหัสด้านบน คุณช่วยฉันหน่อยได้ไหม
Jiks

4
แต่ละคลาสภายในในโมเดลต้องเป็นอนุกรม
Samir Mangroliya

55

OneThread Class ของคุณควรใช้ Serializable คลาสย่อยทั้งหมดและคลาสย่อยภายในต้องใช้งาน Serializableได้

มันใช้งานได้สำหรับฉัน ...


24

ถ้าคุณไม่สามารถทำให้ DNode เป็นอนุกรมวิธีแก้ปัญหาที่ดีก็คือการเพิ่ม "transient" ให้กับตัวแปร

ตัวอย่าง:

public static transient DNode dNode = null;

สิ่งนี้จะละเว้นตัวแปรเมื่อใช้ Intent.putExtra (... )


2
transientคำหลักใน Java จะใช้ในการแสดงให้เห็นว่าสนามไม่ควรต่อเนื่อง คำตอบแบบเต็มนี่: stackoverflow.com/a/910522/1306012
Bruno Bieri


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

ปัญหาเกิดขึ้นเมื่อคลาสที่คุณกำหนดเองสำหรับคุณสมบัติคลาสอื่นเช่น "Bitmap" สิ่งที่ฉันทำคือการเปลี่ยนฟิลด์คุณสมบัติจาก "รูปถ่ายบิตแมปส่วนตัว" เป็น "รูปถ่ายบิตแมปชั่วคราว" อย่างไรก็ตามภาพว่างเปล่าหลังจากฉัน 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

ฉันยังเฟสข้อผิดพลาดเหล่านี้และฉันเปลี่ยนแปลงเล็กน้อยในmodelClass ซึ่งมีการใช้อินเตอร์เฟส Serializableเช่น:

ที่ว่ารูปแบบการเรียนยังใช้อินเตอร์เฟซ ParcelableกับwriteToParcel ()วิธีการแทนที่

แล้วก็มีข้อผิดพลาดในการ"สร้างสร้าง"เพื่อCREATORคือเขียนและยังสร้างด้วยmodelclass contructor มีข้อโต้แย้งและโดยไม่ขัดแย้ง ..

       @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

ต้องการเปลี่ยน arraylist ทั้งหมดเป็น Serialif wif ในคลาส bean:

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.