读书笔记-Android对象序列化

    xiaoxiao2021-04-02  37

    为什么要序列化对象:

    1通过使用Intent和Binder传输对象 2把对象持久化到存储设备或通过网络传输给其他客户端

    序列化的两种方式:Serializable接口和Parcelable接口

    1 Serializable接口

      Serializable接口是java所提供的序列化空接口,只为对象提供标准的序列化和反序列化操作,类直接实现该接口即可。

     serialVersionUID的作用:首先它是privat static final long 类型。它的作用辅助序列化和反序列化,如果类显式的指定serialVersionUID的值,序列化过程中会把该值一同写入第三方介质中,在反序列化过程中就会检测文件中的serialVersionUID值和类中的serialVersionUID是否一致,一致成功,否则失败。如果类中没有显式的指定serialVersionUID值,序列化会把hash值写入第三方介质中,当类中增加或删除某个变量,hash值变化,会导致反序列化失败。显式指定serialVersionUID很好的提高反序列化的成功率,但是,如果类发生结构性改变,比如类名、类型发生改变,就算类中显示指定serialVersionUID值并在反序列化中对比一致,程序也crash。

    注:

    1 static和transient后的变量不能被序列化

    2 父类实现该接口,子类可自动序列化

    3 类中的实例变量是其他引用类型,序列化该对象时也会把引用类型序列化

    2 Parcelable接口

     Parcelable接口是Android中序列化方式,效率高但使用麻烦。一般在跨进程通信中使用Parcelable接口,其他保存对象和网络传输对象等用Serializable接口,效率没有Parcelable接口高,但能接受。

    实现Parcelable接口类如下:

    public class Tester implements Parcelable { private String name; private int age; public Tester(){ } public Tester(String name,int age){ this.name=name; this.age=age; } //从序列化后对象中创建原对象 protected Tester(Parcel in) { name=in.readString(); age=in.readInt(); } //当前对象写入序列化结构中 @Override public void writeToParcel(Parcel dest, int flags) { //flags 有0和1两个标识符,1要求当前对象作为返回值,不会立即释放资源,一般情况下是0 dest.writeInt(age); dest.writeString(name); } @Override public int describeContents() { //返回当前对象的内容描述,没有文件标志位返回0,一般返回0 return 0; } public static final Creator<Tester> CREATOR = new Creator<Tester>() { @Override public Tester createFromParcel(Parcel in) { return new Tester(in); } @Override public Tester[] newArray(int size) { //创建指定长度的原对象数组 return new Tester[size]; } }; }

    转载请注明原文地址: https://ju.6miu.com/read-665820.html

    最新回复(0)