小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

Android 使用Parcelable序列化對象

 QCamera 2015-05-30
        Android序列化對象主要有兩種方法,實現(xiàn)Serializable接口、或者實現(xiàn)Parcelable接口。實現(xiàn)Serializable接口是Java SE本身就支持的,而Parcelable是Android特有的功能,效率比實現(xiàn)Serializable接口高,而且還可以用在IPC中。實現(xiàn)Serializable接口非常簡單,聲明一下就可以了,而實現(xiàn)Parcelable接口稍微復雜一些,但效率更高,推薦用這種方法提高性能。下面就介紹一下實現(xiàn)Parcelable接口的方法
        通過實現(xiàn)Parcelable接口序列化對象的步驟:
        1、聲明實現(xiàn)接口Parcelable
        2、實現(xiàn)Parcelable的方法writeToParcel,將你的對象序列化為一個Parcel對象
        3、實例化靜態(tài)內部對象CREATOR實現(xiàn)接口Parcelable.Creator:
Java代碼  收藏代碼
  1. public static final Parcelable.Creator<T> CREATOR  

       其中public static final一個都不能少,內部對象CREATOR的名稱也不能改變,必須全部大寫。
        4、完成CREATOR的代碼,實現(xiàn)方法createFromParcel,將Parcel對象反序列化為你的對象

        簡而言之:通過writeToParcel將你的對象映射成Parcel對象,再通過createFromParcel將Parcel對象映射成你的對象。也可以將Parcel看成是一個流,通過writeToParcel把對象寫到流里面,在通過createFromParcel從流里讀取對象,只不過這個過程需要你來實現(xiàn),因此寫的順序和讀的順序必須一致。
       
        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()  


        也可以讀取或寫入他們的數(shù)組
Java代碼  收藏代碼
  1. writeBooleanArray(boolean[]), readBooleanArray(boolean[]), createBooleanArray()  
  2. writeByteArray(byte[]), writeByteArray(byte[], int, int), 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./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 { //聲明實現(xiàn)接口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.     //實現(xiàn)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.     //實例化靜態(tài)內部對象CREATOR實現(xiàn)接口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. }  

    本站是提供個人知識管理的網(wǎng)絡存儲空間,所有內容均由用戶發(fā)布,不代表本站觀點。請注意甄別內容中的聯(lián)系方式、誘導購買等信息,謹防詐騙。如發(fā)現(xiàn)有害或侵權內容,請點擊一鍵舉報。
    轉藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多