今天給你們介紹Parcelable和Serializable的做用、效率、區別及選擇,關於Serializable的介紹見Java 序列化的高級認識。java
1、做用android
Serializable的做用是爲了保存對象的屬性到本地文件、數據庫、網絡流、rmi以方便數據傳輸,固然這種傳輸能夠是程序內的也能夠是兩個程序間的。而Android的Parcelable的設計初衷是由於Serializable效率過慢,爲了在程序內不一樣組件間以及不一樣Android程序間(AIDL)高效的傳輸數據而設計,這些數據僅在內存中存在,Parcelable是經過IBinder通訊的消息的載體。數據庫
2、效率及選擇編程
Parcelable的性能比Serializable好,在內存開銷方面較小,因此在內存間數據傳輸時推薦使用Parcelable,如activity間傳輸數據,而Serializable可將數據持久化方便保存,因此在須要保存或網絡傳輸數據時選擇Serializable,由於android不一樣版本Parcelable可能不一樣,因此不推薦使用Parcelable進行數據持久化網絡
3、編程實現函數
對於Serializable,類只須要實現Serializable接口,並提供一個序列化版本id(serialVersionUID)便可。而Parcelable則須要實現writeToParcel、describeContents函數以及靜態的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關鍵字對部分字段不進行序列化,也能夠覆蓋writeObject、readObject方法以實現序列化過程自定義
其餘:
android.os.BadParcelableException: ClassNotFoundException when unmarshalling
另外建議APP開發完能夠作一個全面的檢測:http://www.ineice.com/