Android Parcelable和Serializable的區別

今天給你們介紹ParcelableSerializable的做用、效率、區別及選擇,關於Serializable的介紹見Java 序列化的高級認識。java

 

1、做用android

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

 

2、效率及選擇編程

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

 

3、編程實現函數

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

 

Parcelable的一個實現例子以下:spa

從上面咱們能夠看出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

 

4、高級功能上

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

 

其餘:

android.os.BadParcelableException: ClassNotFoundException when unmarshalling

 

另外建議APP開發完能夠作一個全面的檢測:http://www.ineice.com/

相關文章
相關標籤/搜索