Android 使用Parcelable序列化對象

Android序列化對象主要有兩種方法,實現Serializable接口、或者實現Parcelable接口。實現Serializable接口是Java SE自己就支持的,而Parcelable是Android特有的功能,效率比實現Serializable接口高,並且還能夠用在IPC中。實現Serializable接口很是簡單,聲明一下就能夠了,而實現Parcelable接口稍微複雜一些,但效率更高,推薦用這種方法提升性能。下面就介紹一下實現Parcelable接口的方法 
        經過實現Parcelable接口序列化對象的步驟: 
        一、聲明實現接口Parcelable 
        二、實現Parcelable的方法writeToParcel,將你的對象序列化爲一個Parcel對象 
        三、實例化靜態內部對象CREATOR實現接口Parcelable.Creator:
Java代碼    收藏代碼
  1. public static final Parcelable.Creator<T> CREATOR  

       其中public static final一個都不能少,內部對象CREATOR的名稱也不能改變,必須所有大寫。 
        四、完成CREATOR的代碼,實現方法createFromParcel,將Parcel對象反序列化爲你的對象 

        簡而言之:經過writeToParcel將你的對象映射成Parcel對象,再經過createFromParcel將Parcel對象映射成你的對象。也能夠將Parcel當作是一個流,經過writeToParcel把對象寫到流裏面,在經過createFromParcel從流裏讀取對象,只不過這個過程須要你來實現,所以寫的順序和讀的順序必須一致。 
        
        Parcel對象能夠經過如下方法寫入或讀取byte, double, float, int, long, String這6種類型變量。
 
Java代碼    收藏代碼
  1. writeByte(byte), readByte()  
  2. writeDouble(double), readDouble()  
  3. writeFloat(float), readFloat()  
  4. writeInt(int), readInt()  
  5. writeLong(long), readLong()  
  6. writeString(String), readString()  


        也能夠讀取或寫入他們的數組 
Java代碼    收藏代碼
  1. writeBooleanArray(boolean[]), readBooleanArray(boolean[]), createBooleanArray()  
  2. writeByteArray(byte[]), writeByteArray(byte[], intint), readByteArray(byte[]), createByteArray()  
  3. writeCharArray(char[]), readCharArray(char[]), createCharArray()  
  4. writeDoubleArray(double[]), readDoubleArray(double[]), createDoubleArray()  
  5. writeFloatArray(float[]), readFloatArray(float[]), createFloatArray()  
  6. writeIntArray(int[]), readIntArray(int[]), createIntArray()  
  7. writeLongArray(long[]), readLongArray(long[]), createLongArray()  
  8. writeStringArray(String[]), readStringArray(String[]), createStringArray()  
  9. writeSparseBooleanArray(SparseBooleanArray), readSparseBooleanArray()  


        更多操做能夠參閱: 
http://developer.android.com/reference/android/os/Parcel.html 
示例代碼:
 
Java代碼    收藏代碼
  1. package com.ipjmc.demo.parcelable;  
  2.   
  3.   
  4. import java.util.Date;  
  5.   
  6. import android.os.Parcel;  
  7. import android.os.Parcelable;  
  8.   
  9. public class ParcelableDate implements Parcelable { //聲明實現接口Parcelable  
  10.   
  11.     //這裏定義了兩個變量來講明讀和寫的順序要一致  
  12.     public long mId;  
  13.     public Date mDate;  
  14.       
  15.     public ParcelableDate(long id, long time) {  
  16.         mId = id;  
  17.         mDate = new Date(time);  
  18.     }  
  19.       
  20.     public ParcelableDate(Parcel source) {  
  21.         //先讀取mId,再讀取mDate  
  22.         mId = source.readLong();  
  23.         mDate = new Date(source.readLong());  
  24.     }  
  25.       
  26.     @Override  
  27.     public int describeContents() {  
  28.         return 0;  
  29.     }  
  30.   
  31.     //實現Parcelable的方法writeToParcel,將ParcelableDate序列化爲一個Parcel對象  
  32.     @Override  
  33.     public void writeToParcel(Parcel dest, int flags) {   
  34.         //先寫入mId,再寫入mDate  
  35.         dest.writeLong(mId);  
  36.         dest.writeLong(mDate.getTime());  
  37.     }  
  38.   
  39.     //實例化靜態內部對象CREATOR實現接口Parcelable.Creator  
  40.     public static final Parcelable.Creator<ParcelableDate> CREATOR = new Creator<ParcelableDate>() {  
  41.           
  42.         @Override  
  43.         public ParcelableDate[] newArray(int size) {  
  44.             return new ParcelableDate[size];  
  45.         }  
  46.           
  47.         //將Parcel對象反序列化爲ParcelableDate  
  48.         @Override  
  49.         public ParcelableDate createFromParcel(Parcel source) {  
  50.             return new ParcelableDate(source);  
  51.         }  
  52.     };  
  53. }  
相關文章
相關標籤/搜索