Parcelable和Serializable的区别

本文对比了Android中的两种序列化方式:Serializable与Parcelable。详细解析了Parcelable接口的使用方法,包括序列化、反序列化及内容描述符的过程。并通过示例代码展示了如何实现Parcelable接口。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我们知道andriod在本地存储对象或者用intent传递对象的时候,需要把对象序列化才能够对其进行操作,在java中我们所熟悉的是对象实现serializable接口即可,而在andriod中官方推荐使用的是Parcelable接口,两者有什么区别呢?
1.Serializable是java中的序列化接口,使用简单但是开销比较大,序列化合反序列化需要大量的I/O操作。
2.Parcelable是andriod中的序列化方式,因此有更适合andriod平台的有点是序列化合反序列化的效率高,但是其缺点就是使用起来比较麻烦,使用过Parcelable接口的同学应该知道实现Parcelable接口需要有序列化,反序列化,内容描述符这几个过程。
1).序列化由writeToParcel方法来完成,最终通过Parcel中的恶意系列write方法来完成的。
2).反序列化功能则由CREATOR来完成,其内部标明了如何创建序列化对象和数组,并通过Parcel的一系列read方法来完成反序列化过程;内容描述符功能有describeCoontnets方法来完成,几乎在所有情况下这个方法东应该返回0,仅当当前对象中存在文件描述符时,返回1。另外需要注意的是,在序列化对象的类里面如果其它可序列化对象,则序列化过程需要传递当前县城的上下文类加载器,否则汇报无法找到类的错误。
3).举个栗子:
public class Man implements Parcelable{
public int userId;
public String userName;
public boolean isMale;
public Dog dog;
public User(int userId,String userName,boolean isGood){
this.userId=userId;
this.userName=userName;
this.isMale=isMale;
}
public int describeContents(){
return 0;
}
public void writeToParcel(Parcel out,int flags){
out.writeInt(userId);
out.writeString (userName);
out.writeInt(isMale?1:0);
out.writeparcelable(dog,0);
}
public static final Parcelable.Creator<Man> CREATOR=new Parcelable.Creator<Man>(){
public User createFromParcel(Parcel in){
return new Man(in);
}
public Man[] newArray(int size){
return new Man[size];
}
};
private Man(Parcel in){
userId=in.readInt();
userName=in.readString();
isMale=in.readInt()==1;
book=in.readParcelable(Thrad.currentThread().getContextClassLoader());
}
}
参考资料:Andriod 开发艺术探索
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值