Android Parcelable和Serializable的區別

Android Parcelable和Serializable的區別

本文主要介紹Parcelable和Serializable的做用、效率、區別及選擇,關於Serializable的介紹見Java 序列化的高級認識html

 

一、做用 java

Serializable的做用是爲了保存對象的屬性到本地文件、數據庫、網絡流、rmi以方便數據傳輸,固然這種傳輸能夠是程序內的也能夠是兩個程序間的。而Android的Parcelable的設計初衷是由於Serializable效率過慢,爲了在程序內不一樣組件間以及不一樣Android程序間(AIDL)高效的傳輸數據而設計,這些數據僅在內存中存在,Parcelable是經過IBinder通訊的消息的載體。 android

從上面的設計上咱們就能夠看出優劣了。 數據庫

 

二、效率及選擇 編程

Parcelable的性能比Serializable好,在內存開銷方面較小,因此在內存間數據傳輸時推薦使用Parcelable,如activity間傳輸數據,而Serializable可將數據持久化方便保存,因此在須要保存或網絡傳輸數據時選擇Serializable,由於android不一樣版本Parcelable可能不一樣,因此不推薦使用Parcelable進行數據持久化 網絡

 

三、編程實現 函數

對於Serializable,類只須要實現Serializable接口,並提供一個序列化版本id(serialVersionUID)便可。 而Parcelable則須要實現writeToParcel、describeContents函數以及靜態的CREATOR變量,實際上就是將如何打包和解包的工做本身來定義,而序列化的這些操做徹底由底層實現性能

Parcelable的一個實現例子以下 spa

複製代碼
public class MyParcelable implements Parcelable { private int mData; private String mStr; public int describeContents() { return 0; } // 寫數據進行保存 public void writeToParcel(Parcel out, int flags) { out.writeInt(mData); out.writeString(mStr); } // 用來建立自定義的Parcelable的對象 public static final Parcelable.Creator<MyParcelable> CREATOR = new Parcelable.Creator<MyParcelable>() { public MyParcelable createFromParcel(Parcel in) { return new MyParcelable(in); } public MyParcelable[] newArray(int size) { return new MyParcelable[size]; } }; // 讀數據進行恢復 private MyParcelable(Parcel in) { mData = in.readInt(); mStr = in.readString(); } }
複製代碼

從上面咱們能夠看出Parcel的寫入和讀出順序是一致的。若是元素是list讀出時須要先new一個ArrayList傳入,不然會報空指針異常。以下: 設計

list = new ArrayList<String>(); in.readStringList(list);

 PS: 在本身使用時,read數據時誤將前面int數據看成long讀出,結果後面的順序錯亂,報以下異常,當類字段較多時務必保持寫入和讀取的類型及順序一致

11-21 20:14:10.317: E/AndroidRuntime(21114): Caused by: java.lang.RuntimeException: Parcel android.os.Parcel@4126ed60: Unmarshalling unknown type code 3014773 at offset 164

 

四、高級功能上

Serializable序列化不保存靜態變量,可使用Transient關鍵字對部分字段不進行序列化,也能夠覆蓋writeObject、readObject方法以實現序列化過程自定義

 

參考:

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

相關文章
相關標籤/搜索