原创文章。转载请注明 http://blog.csdn.net/leejizhou/article/details/51105060 李济洲的博客

Intent的使用方法相信你已经比較熟悉了,Intent能够用来启动Activity,Service等等,同一时候我们也能够通过Intent来进行传递数据,比方以下代码

                Intent intent=new Intent(MainActivity.this,OtherActivity.class);
intent.putExtra("name","lijizhou");
intent.putExtra("age",22);
startActivity(intent);

putExtra尽管能够传递大多数的Java数据类型。但还是有限的,当你想传递一些自己定义对象的时候就会发现无从下手,SO,本篇博文介绍下利用Intent传递对象的几种实现方式,Android中Intent传递对象有两种方式一种是通过实现Serializable接口传递对象。一种是通过实现Parcelable接口传递对象。Serializable是Java提供的序列化接口,而Parcelable的Android团队设计的,两者各有利弊。

以下先介绍Serializable怎样使用

Serializable是序列化的意思,表示将一个对象转换成可储存或可传输的状态。对象进行Serializable序列化之后就能够通过Intent来进行Activity之间的传输了。

比方像以下这样SerObject类实现Serializable接口 —- SerObject.java

public class SerObject implements Serializable {
private static final long serialVersionUID=1L;
private String name;
private String age;
public String getAge() {
return age;
}
public void setAge(String age) {
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
} }

这里面的serialVersionUID须要注意一下,它的作用是序列化和反序列化时保持版本号的兼容性,假设你未指定,执行时也会默认生成。在进行反序列化时仅仅有数据和当前类的serialVersionUID同样是才干够正常的反序列化。你不指定serialVersionUID普通情况下也不会出问题。可是假设当前类发生了改变比如删掉了某个成员变量那么当前类的serialVersionUID也会出现改变,之后你对数据进行反序列化就会出现错误,这里我指定为1L,L为Long数据类型。

接下来进行对象的传递 ,通过Intent携带对象数据。来启动Activity2

                SerObject obj=new SerObject();
obj.setName("Serializable");
obj.setAge("22");
Intent mIntent = new Intent(MainActivity.this,Activity2.class);
mIntent.putExtra("Ser",obj);
startActivity(mIntent);

然后在Activity2中读取数据并打印

            SerObject serObject = (SerObject)getIntent().getSerializableExtra("Ser");
Log.i("log",serObject.getName()+"----"+serObject.getAge());

通过Log能够看出成功的将对象传到了Activity2中

Serializable的使用非常easy。以下介绍下Parcelable的接口怎样实现

Parcelable的序列化原理是将一个对象进行分解,而分解后的每一部分都是Intent所支持的数据类型。因此实现了传递对象的功能。

比如以下的 ParObject类

public class ParObject implements Parcelable {
private String name;
private String age; public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getAge() {
return age;
}
public void setAge(String age) {
this.age = age;
} @Override
public int describeContents() {
return 0;
} @Override
public void writeToParcel(Parcel dest, int flags) { dest.writeString(name);
dest.writeString(age);
} protected ParObject(Parcel in) {
name = in.readString();
age = in.readString();
}
public ParObject(){ }
public static final Creator<ParObject> CREATOR = new Creator<ParObject>() {
@Override
public ParObject createFromParcel(Parcel in) {
return new ParObject(in);
} @Override
public ParObject[] newArray(int size) {
return new ParObject[size];
}
}; }

能够看到通过Parcelable的实现方式是要复杂非常多的。实现Parcelable接口后。须要重写writeToParcel和describeContents方法,describeContents方法直接返回0就能够了,writeToParcel方法我们须要调用Parcel对象进行数据写入,比如dest.writeString(name),注意假设name是字符串类型就调用writeString,假设是Int类型就调用writeInt 等等,參考上面代码。

然后还要在这个类中实现一个名为CREATOR的常量,这里创建了Parcelable.Creator接口的一个实现,并将泛型指定为ParObject(參考上面代码),然后去重写createFromParcel和newArray两个方法,在createFromParcel中通过

Parcel去读取刚才通过writeToParcel写入的数据并返回ParObject对象,注意这里的read要和write时候的顺序一样,newArray方法仅仅要new 一个ParObject类的数组。并将size作为数组大小就OK了。

这样Parcelable的接口实现就OK了。缺点就是数据写入和读取等等方法须要手动去实现

。我相信你看的脑袋都大了,当然不能忘了Android Studio这个强大的工具,当你写好java类并实现了Parcelable 那么兴许的writeToParcel createFromParcel newArray等等一系列繁琐代码都将自己主动实现。

类实现Parcelable 然后点到类名上 Alt+enter:

接下来对象的传递就简单多了 和Serializable相似

                ParObject obj=new ParObject();
obj.setName("Parcelable");
obj.setAge("22");
Intent mIntent = new Intent(MainActivity.this,Activity2.class);
mIntent.putExtra("Par",obj);
startActivity(mIntent);

然后在Activitry2中接收并打印

            ParObject parObject = (ParObject)getIntent().getParcelableExtra("Par");
Log.i("log",parObject.getName()+"----"+parObject.getAge());

对象成功传递

Ok 通过Intent传递对象的两种方式介绍完了,Serializable和Parcelable各有利弊,Serializable代码简单,可是开销非常大。对androidAPP的性能会有一定的影响,相比,Parcelable使用起来比較麻烦,可是效率比較高,也是android推荐的序列化方式。总结:在内存中的序列化比如Intent传递推荐Parcelable。存储到设备或者进行网络传输推荐Serializable。欢迎大家在下方留言

PS 以后訪问我的博客能够直接在浏览器键入 www.lijizhou.com就会自己主动跳转到CSDN

本篇博文 源码下载地址 http://download.csdn.net/detail/leejizhou/9485885

Intent传递对象的几种方式的更多相关文章

  1. Intent传递对象的两种方法

    Android为intent提供了两种传递对象参数类型的方法 分别需要使实体类实现Serializable接口.Parcelable接口 首先我们要知道,传递对象,需要先将对象序列化 一.那么为什么要 ...

  2. Intent传递对象的两种方法(Serializable,Parcelable) (转)

    今天讲一下Android中Intent中如何传递对象,就我目前所知道的有两种方法,一种是Bundle.putSerializable(Key,Object);另一种是Bundle.putParcela ...

  3. Android中Intent传递对象的两种方法(Serializable,Parcelable)

    今天要给大家讲一下Android中 Intent中如何传递对象,就我目前所知道的有两种方法,一种是Bundle.putSerializable(Key,Object);另一种是 Bundle.putP ...

  4. [转]Android中Intent传递对象的两种方法(Serializable,Parcelable)

    http://blog.csdn.net/xyz_lmn/article/details/5908355 今天要给大家讲一下Android中Intent中如何传递对象,就我目前所知道的有两种方法,一种 ...

  5. Android高手进阶教程(十七)之---Android中Intent传递对象的两种方法(Serializable,Parcelable)!

    [转][原文] 大家好,好久不见,今天要给大家讲一下Android中Intent中如何传递对象,就我目前所知道的有两种方法,一种是Bundle.putSerializable(Key,Object); ...

  6. 使用Intent传递对象

    Intent 的用法相信你已经比较熟悉了,我们可以借助它来启动活动.发送广播.启动服务等.在进行上述操作的时候,我们还可以在Intent 中添加一些附加数据,以达到传值的效果,比如在FirstActi ...

  7. Android开发——使用intent传递对象

    intent传递对象有两种方法: 方式一:Serializable 方式 方式二:Parcelable方式 在这里不多介绍了,这一篇就是快速上手使用教程,至于详细原理介绍的,请看这一篇http://w ...

  8. Android 全局获取 Context 与使用 Intent 传递对象

    =====================全局获取 Context======================== Android 开发中很多地方需要用到 Context,比如弹出 Toast.启动活 ...

  9. Android学习笔记(十二)——使用意图传递数据的几种方式

    使用意图传递数据的几种方式 点此获取完整代码 我们除了要从活动返回数据,也经常要传递数据给活动.对此我们能够使用Intent对象将这些数据传递给目标活动. 1.创建一个名为PassingData的项目 ...

随机推荐

  1. 第一个C#控制台程序

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  2. 关于ajax访问express服务器的跨域问题

    在学习es6的时候用promise封装了一个ajax <script type="text/javascript"> function getNews(URL) { l ...

  3. css3新特性选择器(补充)

    1.选择p标签中的第一个字符 p:first-letter{ color:red; font-size:25px; } 2.选择p标签中的第一行 p:first-line{ color:red; fo ...

  4. 4.cocos场景和层的调用

    调用关系: AppDeligate.cpp bool AppDelegate::applicationDidFinishLaunching() { // initialize director aut ...

  5. POJ 3051 DFS

    题意:判断连通块大小 水题 //By SiriusRen #include <cstdio> #include <cstring> #include <algorithm ...

  6. 洛谷P3531 [POI2012]LIT-Letters

    题目描述 Little Johnny has a very long surname. Yet he is not the only such person in his milieu. As it ...

  7. Checkpoint & cache & persist

    checkpoint checkpoint(检查点)是Spark为了避免长链路,大计算量的Rdd不可用时,需要长时间恢复而引入的.主要就是将通过大量计算而获得的这类Rdd的数据直接持久化到外部可靠的存 ...

  8. 洛谷——P1843 奶牛晒衣服

    https://www.luogu.org/problem/show?pid=1843#sub 题目背景 熊大妈决定给每个牛宝宝都穿上可爱的婴儿装 . 于是 , 为牛宝宝洗晒衣 服就成了很不爽的事情. ...

  9. 利用JAVA反射机制实现调用私有方法

    1.fragment是AccessibilityFragment的對象.须要被調用的方法的類. setAccessible(true)并非将方法的訪问权限改成了public.而是取消java的权限控制 ...

  10. 为您的Office文档加把锁-ADRMS的安装

    为您的Office文档加把锁-ADRMS的安装 如今不少企业越来越重视自己KM(知识管理系统)的建立对于KM的建立实施虽然可以有效地解决企业在知识管理上的问题对于一些具有商业利益关系的机密文件(例如: ...