您的位置:首页 > 移动开发 > Android开发

Android 使用Parcelable序列化对象

2012-07-20 15:54 309 查看
Android序列化对象主要有两种方法,实现Serializable接口、或者实现Parcelable接口。实现Serializable接口是Java SE本身就支持的,而Parcelable是Android特有的功能,效率比实现Serializable接口高,而且还可以用在IPC中。实现Serializable接口非常简单,声明一下就可以了,而实现Parcelable接口稍微复杂一些,但效率更高,推荐用这种方法提高性能。下面就介绍一下实现Parcelable接口的方法

通过实现Parcelable接口序列化对象的步骤:

1、声明实现接口Parcelable

2、实现Parcelable的方法writeToParcel,将你的对象序列化为一个Parcel对象

3、实例化静态内部对象CREATOR实现接口Parcelable.Creator:

Java代码


public static final Parcelable.Creator<T> CREATOR

其中public static final一个都不能少,内部对象CREATOR的名称也不能改变,必须全部大写。

4、完成CREATOR的代码,实现方法createFromParcel,将Parcel对象反序列化为你的对象

简而言之:通过writeToParcel将你的对象映射成Parcel对象,再通过createFromParcel将Parcel对象映射成你的对象。也可以将Parcel看成是一个流,通过writeToParcel把对象写到流里面,在通过createFromParcel从流里读取对象,只不过这个过程需要你来实现,因此写的顺序和读的顺序必须一致。

Parcel对象可以通过以下方法写入或读取byte, double, float, int, long, String这6种类型变量。

Java代码


writeByte(byte), readByte()
writeDouble(double), readDouble()
writeFloat(float), readFloat()
writeInt(int), readInt()
writeLong(long), readLong()
writeString(String), readString()

也可以读取或写入他们的数组

Java代码


writeBooleanArray(boolean[]), readBooleanArray(boolean[]), createBooleanArray()
writeByteArray(byte[]), writeByteArray(byte[], int, int), readByteArray(byte[]), createByteArray()
writeCharArray(char[]), readCharArray(char[]), createCharArray()
writeDoubleArray(double[]), readDoubleArray(double[]), createDoubleArray()
writeFloatArray(float[]), readFloatArray(float[]), createFloatArray()
writeIntArray(int[]), readIntArray(int[]), createIntArray()
writeLongArray(long[]), readLongArray(long[]), createLongArray()
writeStringArray(String[]), readStringArray(String[]), createStringArray()
writeSparseBooleanArray(SparseBooleanArray), readSparseBooleanArray()

更多操作可以参阅:

http://developer.android.com/reference/android/os/Parcel.html

示例代码:

Java代码


package com.ipjmc.demo.parcelable;

import java.util.Date;

import android.os.Parcel;
import android.os.Parcelable;

public class ParcelableDate implements Parcelable { //声明实现接口Parcelable

//这里定义了两个变量来说明读和写的顺序要一致
public long mId;
public Date mDate;

public ParcelableDate(long id, long time) {
mId = id;
mDate = new Date(time);
}

public ParcelableDate(Parcel source) {
//先读取mId,再读取mDate
mId = source.readLong();
mDate = new Date(source.readLong());
}

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

//实现Parcelable的方法writeToParcel,将ParcelableDate序列化为一个Parcel对象
@Override
public void writeToParcel(Parcel dest, int flags) {
//先写入mId,再写入mDate
dest.writeLong(mId);
dest.writeLong(mDate.getTime());
}

//实例化静态内部对象CREATOR实现接口Parcelable.Creator
public static final Parcelable.Creator<ParcelableDate> CREATOR = new Creator<ParcelableDate>() {

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

//将Parcel对象反序列化为ParcelableDate
@Override
public ParcelableDate createFromParcel(Parcel source) {
return new ParcelableDate(source);
}
};
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: