上一篇中我们透过源码看到了Parcel背后的机制,本质上把它当成一个Serialize就可以了,只是它是在内存中完成的序列化和反序列化,利用的是连续的内存空间,因此会更加高效。
我们接下来要说的是Parcel类如何应用。就应用程序而言,最常见使用Parcel类的场景就是在Activity间传递数据。没错,在Activity间使用Intent传递数据的时候,可以通过Parcelable机制传递复杂的对象。
在下面的程序中,MyColor用于保存一个颜色值,MainActivity在用户点击屏幕时将MyColor对象设成红色,传递到SubActivity中,此时SubActivity的TextView显示为红色的背景;当点击SubActivity时,将颜色值改为绿色,返回MainActivity,期望的是MainActivity的TextView显示绿色背景。
来看一下MyColor类的实现代码:
该类实现了Parcelable接口,提供了默认的构造函数,同时也提供了可从Parcel对象开始的构造函数,另外还实现了一个static的构造器用于构造对象和数组。代码很简单,不一一解释了。
再看MainActivity的代码:
下面是SubActivity的代码:
下面是main.xml的代码:
注意的是在MainActivity的onActivityResult()中,有一句color=data.getParcelableExtra("MyColor"),这说明的是反序列化后是一个新的MyColor对象,因此要想使用这个对象,我们做了这个赋值语句。
记得在上一篇《探索Android中的Parcel机制(上)》中提到,如果数据本身是IBinder类型,那么反序列化的结果就是原对象,而不是新建的对象,很显然,如果是这样的话,在反序列化后在MainActivity中就不再需要color=data.getParcelableExtra("MyColor")这句了。因此,换一种MyColor的实现方法,令其中的int color成员变量使用IBinder类型的成员变量来表示。
新建一个BinderData类继承自Binder,代码如下:
修改MyColor的代码如下:
去掉MainActivity的onActivityResult()中的color=data.getParcelableExtra("MyColor")一句,变成:
再次运行程序,结果符合预期。
以上就是Parcel在应用程序中的使用方法,与Serialize还是挺相似的,详细的资料当然还是要参考Android SDK的开发文档了。
——欢迎转载,请注明出处 http://blog.csdn.net/caowenbin ——
分享到:
相关推荐
本文实例讲述了Android中Parcel用法。分享给大家供大家参考,具体如下: Android 中Parcel 的使用,他是一个存储基本数据类型和引用数据类型的容器,在andorid 中通过IBinder来绑定数据在进程间传递数据。 Parcel ...
探索Android中的Parcel机制.doc
主要介绍了Android开发之Parcel机制,实例分析了Parcel机制的原理与实现技巧,需要的朋友可以参考下
序列化之parcel的源码,anroid存储数据的一种方式,希望对你有用哦
AutoParcel AutoParcel is an AutoValue extension that enables Parcelable values generation. Just add implements Parcelable to your @AutoValue annotated models. @AutoValue abstract class Person ...
这里介绍了如何使用parcel接口,方便学习和开发。
这个是native服务直接使用Parcel进行通信的一个接口,提供给后面使用。
(以上三个文件放入 /opt/cloudera/parcel-repo/ 下) FLINK_ON_YARN-1.14.4.jar FLINK-1.14.4.jar (以上三个文件放入 /opt/cloudera/csd/ 下) 另外需要将以下两个包放入 /opt/cloudera/parcels/FLINK/lib/...
CDH5.16.1集成Flink1.10.0 parcel文件,csd文件。Centos7.5编译。亲测可用。
FLINK-1.13.2-BIN-SCALA_2.11-el7.parcel.sha FLINK-1.13.2-BIN-SCALA_2.11-el7.parcel manifest.json FLINK_ON_YARN-1.13.2.jar 安装教程见 ...
flink parcel在线编译成功的,flink1.14.3版本
使用parcel打包构建vue应用初始模板
全新Parcel打包工具VueJS急速开发脚手架解决方案。parcel-vue 一个基于Parcel打包工具的 VueJS急速开发脚手架解决方案。
因为CDH-6.3.2-1.cdh6.3.2.p0.1605554-el7.parcel命令生成的CDH-6.3.2-1.cdh6.3.2.p0.1605554-el7.parcel.sha1文件hash不匹配,自己找到官网上的parcel.sha1文件解决了这个问题,共享给大家
flink parcel在线编译成功的,flink1.12.0版本 包含FLINK-1.12.0-BIN-SCALA_2.12-el7.parcel FLINK-1.12.0-BIN-SCALA_2.12-el7.parcel.sha manifest.json
CDH Parcel5.13.0 el6版本,第二部分,用于CDH大数据环境搭建
这是一个超小的例子,透明地比较了parcel和webpack
phoenix-parcel-5.0.0-cdh6.2.0-el7安装包