本文主要先容ParcelableSerializable的作用、效率、区别及选择。

1、作用

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的一个实现例子如下

  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读出,效果后面的顺序庞杂,报如下异常,当类字段较多时务必保持写入和读取的类型及顺序一致。

  12-21 20:14:10.317: E/AndroidRuntime(21114): Caused by: java.lan
g.RuntimeException: Parcel android.os.Parcel@4126ed60: Unmarshal
ling unknown type code 3014773 at offset 164
4、高级功能上

Serializable序列化不保留静态变量,可以使用Transient关键字对部门字段不举行序
列化,也可以笼罩writeObjectreadObject方式以实现序列化历程自界说。

更多内容详情请关注我的GitHub:https://github.com/xiangjiana/Android-MS