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:

Java代碼  收藏代碼
  1. 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代碼  收藏代碼
  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. }
發佈了17 篇原創文章 · 獲贊 13 · 訪問量 21萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章