序列化Serializable/Parcelable

定义

将一个对象转换成可存储可传输的状态。(对象转换成字节流的过程)

作用

对象序列化后,可以在进程间、网络间进行传输,也可以做本地持久化存储

为什么要序列化

对于计算机来说,不认识对象只认识二进制。数据的传输和存储都要通过字节流的方式来进行

Serializable

只需要实现Serializable接口。代码如下:

public class Student implements Serializable {

    /**
     * Java的序列化机制是通过判断类的serialVersionUID来验证版本一致性的。
     * 在进行反序列化时,JVM会把传来的字节流中的serialVersionUID与本地相应实体类的serialVersionUID进行比较,
     * 如果相同就可以进行反序列化,否则就会出现异常,即是InvalidCastException。
     */
    private static final long serialVersionUID = 1L;

    private String sid;
    private String name;
    private int age;
}

Parcelable

需要实现writeToParceldescribeContents函数以及静态的CREATOR变量。

代码如下:

public class Student implements Parcelable {
    private String sid;
    private String name;
    private int age;

    @Override
    public int describeContents() {
        return 0;
    }

    @Override
    public void writeToParcel(Parcel dest, int flags) {
        dest.writeString(this.sid);
        dest.writeString(this.name);
        dest.writeInt(this.age);
    }

    public User() {
    }

    protected User(Parcel in) {
        this.sid = in.readString();
        this.name = in.readString();
        this.age = in.readInt();
    }

    public static final Parcelable.Creator<User> CREATOR = new Parcelable.Creator<User>() {
        @Override
        public User createFromParcel(Parcel source) {
            return new User(source);
        }

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

区别

SerializableParcelable
API所属JAVAAndroid
效率
特点   大量的I/O操作,产生大量的临时变量,速度慢,开销比较大直接在内存中操作,效率高,性能好
适用场景存储到设备或者网络传输内存中数据传输
操作程度简单方便繁琐复杂

  • 8
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值