对于Android来说传递复杂类型,主要是将自己的类转换为基础的字节数组,Activity之间传递数据是通过Intent实现的。Android序列化对象主要有两种方法,实现Serializable接口、或者实现Parcelable接口。实现Serializable接口是Java SE本身就支持的,而Parcelable是Android特有的功能,效率比实现Serializable接口高,而且还可以用在进程间通信(IPC)中。实现Serializable接口非常简单,声明一下就可以了。而实现Parcelable接口稍微复杂一些,但效率更高,推荐用这种方法提高性能。

android 中自定义的对象序列化的问题有两个选择一个是Parcelable,另外一个是Serializable。

一 序列化原因:

1.永久性保存对象,保存对象的字节序列到本地文件中;
2.通过序列化对象在网络中传递对象;
3.通过序列化在进程间传递对象。

二 至于选取哪种可参考下面的原则:

1.在使用内存的时候,Parcelable 类比Serializable性能高,所以推荐使用Parcelable类。
2.Serializable在序列化的时候会产生大量的临时变量,从而引起频繁的GC。
3.Parcelable不能使用在要将数据存储在磁盘上的情况,因为Parcelable不能很好的保证数据的持续性在外界有变化的情况下。尽管Serializable效率低点, 也不提倡用,但在这种情况下,还是建议你用Serializable 。


Parcelable接口的作用:实现了Parcelable接口的实例可以将自身的状态信息(状态信息通常指的是各成员变量的值)写入Parcel,也可以从Parcel中恢复其状态。 Parcel用来完成数据的序列化传递。下面就介绍一下实现Parcelable接口的方法。

通过实现Parcelable接口序列化对象的步骤:

1、实现Parcelable接口。

2、并且实现Parcelable接口的public void writeToParcel(Parcel dest, int flags)方法。

3、自定义类型中必须含有一个名称为CREATOR的静态成员,该成员对象要求实现Parcelable.Creator接口及其方法。

简而言之:通过writeToParcel将你的对象映射成Parcel对象,再通过createFromParcel将Parcel对象映射成你的对象。也可以将Parcel看成是一个流,通过writeToParcel把对象写到流里面,在通过createFromParcel从流里读取对象,只不过这个过程需要你来实现,因此写的顺序和读的顺序必须一致。

示例代码:

[java] view plain copy
  1. packagecom.yang.domain;
  2. importandroid.os.Parcel;
  3. importandroid.os.Parcelable;
  4. publicclassPersonimplementsParcelable{
  5. //这里定义了两个变量来说明读和写的顺序要一致
  6. privateIntegerid;
  7. privateStringname;
  8. publicPerson(){
  9. }
  10. publicPerson(Integerid,Stringname){
  11. this.id=id;
  12. this.name=name;
  13. }
  14. publicIntegergetId(){
  15. returnid;
  16. }
  17. publicvoidsetId(Integerid){
  18. this.id=id;
  19. }
  20. publicStringgetName(){
  21. returnname;
  22. }
  23. publicvoidsetName(Stringname){
  24. this.name=name;
  25. }
  26. @Override
  27. publicintdescribeContents(){
  28. return0;
  29. }
  30. @Override
  31. publicvoidwriteToParcel(Parceldest,intflags){
  32. //把javanbean中的数据写到Parcel。先写id然后写name
  33. dest.writeInt(this.id);
  34. dest.writeString(this.name);
  35. }
  36. //添加一个静态成员,名为CREATOR,该对象实现了Parcelable.Creator接口
  37. publicstaticfinalParcelable.Creator<Person>CREATOR=newParcelable.Creator<Person>(){
  38. @Override
  39. publicPersoncreateFromParcel(Parcelsource){
  40. //从Parcel中读取数据,返回person对象
  41. returnnewPerson(source.readInt(),source.readString());
  42. }
  43. @Override
  44. publicPerson[]newArray(intsize){
  45. returnnewPerson[size];
  46. }
  47. };
  48. }
要传递的数据是由复制数据类型组合而成时:[java] view plain copy
  1. publicclassMyParcelableimplementsParcelable{
  2. privateList<MyListClass>arrList=newArrayList<MyListClass>();
  3. privateintmyInt=0;
  4. privateStringstr=null;
  5. publicStringgetStr(){
  6. returnstr;
  7. }
  8. publicvoidsetStr(Stringstr){
  9. this.str=str;
  10. }
  11. publicList<MyListClass>getArrList(){
  12. returnarrList;
  13. }
  14. publicvoidsetArrList(List<MyListClass>arrList){
  15. this.arrList=arrList;
  16. }
  17. publicintgetMyInt(){
  18. returnmyInt;
  19. }
  20. publicvoidsetMyInt(intmyInt){
  21. this.myInt=myInt;
  22. }
  23. MyParcelable(){
  24. //initialization
  25. arrList=newArrayList<MyListClass>();
  26. }
  27. publicMyParcelable(Parcelin){
  28. myInt=in.readInt();
  29. str=in.readString();
  30. in.readTypedList(arrList,MyListClass.CREATOR);
  31. }
  32. @Override
  33. publicintdescribeContents(){
  34. return0;
  35. }
  36. @Override
  37. publicvoidwriteToParcel(ParceloutParcel,intflags){
  38. outParcel.writeInt(myInt);
  39. outParcel.writeString(str);
  40. outParcel.writeTypedList(arrList);
  41. }
  42. publicstaticfinalParcelable.Creator<MyParcelable>CREATOR=newParcelable.Creator<MyParcelable>(){
  43. @Override
  44. publicMyParcelablecreateFromParcel(Parcelin){
  45. returnnewMyParcelable(in);
  46. }
  47. @Override
  48. publicMyParcelable[]newArray(intsize){
  49. returnnewMyParcelable[size];
  50. }
  51. };
  52. }
当有子类父类情况时[java] view plain copy
  1. publicabstractclassAimplementsParcelable{
  2. privateinta;
  3. protectedA(inta){
  4. this.a=a;
  5. }
  6. publicvoidwriteToParcel(Parcelout,intflags){
  7. out.writeInt(a);
  8. }
  9. protectedA(Parcelin){
  10. a=in.readInt();
  11. }
  12. }
  13. publicclassBextendsA{
  14. privateintb;
  15. publicB(inta,intb){
  16. super(a);
  17. this.b=b;
  18. }
  19. publicstaticfinalParcelable.Creator<B>CREATOR=newParcelable.Creator<B>(){
  20. publicBcreateFromParcel(Parcelin){
  21. returnnewB(in);
  22. }
  23. publicB[]newArray(intsize){
  24. returnnewB[size];
  25. }
  26. };
  27. publicintdescribeContents(){
  28. return0;
  29. }
  30. publicvoidwriteToParcel(Parcelout,intflags){
  31. super.writeToParcel(out,flags);
  32. out.writeInt(b);
  33. }
  34. privateB(Parcelin){
  35. super(in);
  36. b=in.readInt();
  37. }
  38. }

注:Parcelable接口在Android当中有非常之多的子类,如下截图:Parcalable接口使用(android传递结构体数据的方法)_第1张图片
并且Intent当中也定义了很多关于Parcelable的get、set方法,如:
Intent putExtra( Stringname, Parcelablevalue)Add extended data to the intent.
<Textends Parcelable> T getParcelableExtra( Stringname)Retrieve extended data from the intent.
并且Intent本身也实现了Parcelable接口,因此在Android开发当中是非常推荐以Parcelable作为工具传递复制对象。

更多相关文章

  1. 从源码看Android常用的数据结构 ( SDK23版本 ) ( 三 , Queue篇)
  2. Android数据存储方式:SharePreference、SQLite、ContentProvider
  3. Android中数据存储----SQLite数据库
  4. 【Android】Android 多个APK数据共享
  5. Android App开发基础篇—数据存储(SP和文件)
  6. android 数据存储初探
  7. android从网站获取json接口数据并放置到spinner
  8. Android:控件的对象修改控件的值

随机推荐

  1. Windows下git下载android source
  2. android ndk 使用第三方静态库
  3. 【android】checkedTextView形成自定义Li
  4. Android(安卓)API 中文 (55) —— ListAdap
  5. 疯狂android讲义学习总结---TextView
  6. 加速 Android(安卓)开发的五大开源网站
  7. Android界面开发推荐颜色
  8. Android(安卓)EventBus的使用
  9. Android(安卓)SQLite Shell
  10. Android(安卓)AppWidget系统框架