定义
将一个对象转换成可存储
或可传输
的状态。(对象转换成字节流的过程)
作用
对象序列化后,可以在进程间、网络间进行传输,也可以做本地持久化存储
为什么要序列化
对于计算机来说,不认识对象只认识二进制。数据的传输和存储都要通过字节流的方式来进行
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
需要实现writeToParcel
、describeContents
函数以及静态的CREATOR
变量。
代码如下:
public class Student implements Parcelable {private String sid;private String name;private int age;@Overridepublic int describeContents() {return 0;}@Overridepublic 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>() {@Overridepublic User createFromParcel(Parcel source) {return new User(source);}@Overridepublic User[] newArray(int size) {return new User[size];}};
}
区别
Serializable | Parcelable | |
API所属 | JAVA | Android |
效率 | 低 | 高 |
特点 | 大量的I/O操作,产生大量的临时变量,速度慢,开销比较大 | 直接在内存中操作,效率高,性能好 |
适用场景 | 存储到设备或者网络传输 | 内存中数据传输 |
操作程度 | 简单方便 | 繁琐复杂 |