最近在学习Android IPC(Inter-Process Communication)机制时,提到Android 对象的序列化,有两种方法可以实现对象序列化,一种是Serializable接口,另外一种是Parcelable接口。实现Serializable接口是Java SE本身就支持的,而Parcelable是Android特有的功能,效率比实现Serializable接口高,而且还可以用在IPC中。实现Serializable接口非常简单,声明一下就可以了,而实现Parcelable接口稍微复杂一些,但效率更高,推荐用这种方法提高性能。

使用Serializable接口

自定义类MyClass、MyClassA、MyClassB
注意:需定义序列化ID

private static final long serialVersionUID = 1L; // 定义序列化ID

serialVersionUID用来辅助序列化和反序列化过程的,原则上序列化后的数据中serialVersionUID只有和当前类的serialVersionUID相同才能正常的反序列化。

MyClassA:

public class MyClass implements java.io.Serializable {    private static final long serialVersionUID = 1L; // 定义序列化ID    private String a = null;    private int b = 0;    private MyClassA myClassA = new MyClassA;    private List<MyClassB> myClassB = new ArrayList<MyClassB>();}

MyClassA、MyClassB实现方法同上。

MyClass myClass = new MyClass("a", "b", new MyClassA(), new ArrayList<MyClassB>());Intent intent = new Intent(this, SerializableActivity.class);Bundle bundle = new Bundle();bundle.putSerializable("key", myClass);intent.putExtras(bundle);startActivity(intent);MyClass myClass = (MyClass)getIntent().getSerializableExtra("key");Log.d("SerializableActivity", myClass.a);

使用Pacelable接口

重写Parcelable接口中的两个方法和静态变量CREATOR
自定义类MyClass、MyClassA、MyClassB

MyClassA:

public class MyClass implements android.os.Parcelable {    private String a = null;    private int b = 0;    private MyClassA myClassA = new MyClassA;    private List<MyClassB> myClassB = new ArrayList<MyClassB>();    public MyClass(Parcel parcel) {        // 按变量定义的顺序读取        a = parcel.readString();        b = parcel.readInt();        myClassA = parcel.readParcelable(MyClassA.class.getClassLoader());        Parcelable[] pars = parcel.readParcelableArray(MyClassB.class.getClassLoader());        myClassB = Arrays.asList(Arrays.asList(pars).toArray(new MyClassB[pars.length]));    }    @Override    public int describeContents() {        return 0;    }    @Override    public void writeToParcel(Parcel dest, int flags) {        // 按变量定义的顺序写入        dest.writeString(a);        dest.writeString(b);        dest.writeParcelable(myClassA, flags);        dest.writeParcelableArray((myClassB.toArray(new MyClassB[myClassB.size()])), flags);    }    public static final Parcelable.Creator<MyClass> CREATOR = new Parcelable.Creator<MyClass>() {        @Override        public Param createFromParcel(Parcel source) {            return new MyClass(source);        }        @Override        public MyClass[] newArray(int size) {            return new MyClass[size];        }    };}

MyClassA、MyClassB实现方法同上。

TestActivity.java:

MyClass myClass = new MyClass("a", "b", new MyClassA(), new ArrayList<MyClassB>());Intent intent = new Intent(this, ParcelableActivity.class);Bundle bundle = new Bundle();bundle.putParcelable("key", myClass);intent.putExtras(bundle);startActivity(intent);

ParcelableActivity.java:

MyClass myClass = (MyClass)getIntent().getParcelableExtra("key");Log.d("ParcelableActivity", myClass.a);

相比之下,使用Parcelable接口更高效,但是需要实现部分方法,使用Serializable接口更方便,只需要定义一个序列化ID,但是效率比较低。

另外,Parcelable接口为Android特有的,Serializable接口是jre普遍所有的,兼容性更好一点。

至于使用哪种方法,并没有一定的成规可循,要根据实际情况而定。

更多相关文章

  1. [转]JS调用Android里面的方法,Android调用JS里面的方法
  2. 编写自定义的 Android Preference 组件
  3. Android Native代码中的status_t定义
  4. 自定义ListView中的分割线(转)
  5. 3.6.3新版本AndroidStudio报Could not resolve all artifacts fo
  6. Android 自定义实现TextView单行超出部分显示为省略号
  7. Android中Market的Loading效果实现方法
  8. android:TabHost使用方法
  9. Android 自定义控件实现刮刮卡效果 真的就只是刮刮卡么

随机推荐

  1. Android实现动态显示或隐藏密码输入框的
  2. tabcontent中scaleType的使用 图片Drawab
  3. 自学Android(安卓)----- Activity的生命
  4. Android自学笔记之Android常见命令操作及
  5. ASM-使用ASM Bytecode Outline插件查看字
  6. Android Material Design 控件常用的属性
  7. android 调用.net的web Service开发 (KSO
  8. Android程序的目录结构分析——manifests
  9. cocos2d-x学习之旅(四):1.4 使用eclipse
  10. Android中的进程(Process)和线程(Thread)