当前位置: 代码迷 >> Android >> Android 施用Parcelable序列化对象
  详细解决方案

Android 施用Parcelable序列化对象

热度:129   发布时间:2016-05-01 19:33:41.0
Android 使用Parcelable序列化对象
        Android序列化对象主要有两种方法,实现Serializable接口、或者实现Parcelable接口。实现Serializable接口是Java SE本身就支持的,而Parcelable是Android特有的功能,效率比实现Serializable接口高,而且还可以用在IPC中。实现Serializable接口非常简单,声明一下就可以了,而实现Parcelable接口稍微复杂一些,但效率更高,推荐用这种方法提高性能。下面就介绍一下实现Parcelable接口的方法
        通过实现Parcelable接口序列化对象的步骤:
        1、声明实现接口Parcelable
        2、实现Parcelable的方法writeToParcel,将你的对象序列化为一个Parcel对象
        3、实例化静态内部对象CREATOR实现接口Parcelable.Creator:
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种类型变量。

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


        也可以读取或写入他们的数组
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
示例代码:

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);		}	};}
  相关解决方案