1. public class Intent implements Parcelable, Cloneable {   //... private String mAction;
  2. private Uri mData;
  3. private String mType;
  4. private String mPackage;
  5. private ComponentName mComponent;
  6. private int mFlags;
  7. private HashSet<String> mCategories;
  8. private Bundle mExtras;
  9. private Rect mSourceBounds;

转自:http://blog.csdn.net/annkie/article/details/8483253

Intent也是继承了Parcelable的接口。

个人理解,Intent应该只是一个数据参数的载体,真正将两个Acitivity/Service通信起来的是Binder接口(C/S架构)。

第一类:简单或基本数据类型

  1. Intent putExtra(String name, int[] value)
  2. Intent putExtra(String name, float value)
  3. Intent putExtra(String name, byte[] value)
  4. Intent putExtra(String name, long[] value)
  5. Intent putExtra(String name, float[] value)
  6. Intent putExtra(String name, long value)
  7. Intent putExtra(String name, String[] value)
  8. Intent putExtra(String name, boolean value)
  9. Intent putExtra(String name, boolean[] value)
  10. Intent putExtra(String name, short value)
  11. Intent putExtra(String name, double value)
  12. Intent putExtra(String name, short[] value)
  13. Intent putExtra(String name, String value)
  14. Intent putExtra(String name, byte value)
  15. Intent putExtra(String name, char[] value)
  16. Intent putExtra(String name, CharSequence[] value)

本质上仍然是通过一个Bundle(private Bundle mExtras;)来实现:

  1. public Intent putExtra(String name, long value) {
  2. if (mExtras == null) {
  3. mExtras = new Bundle();
  4. }
  5. mExtras.putLong(name, value);
  6. return this;
  7. }

第二类:传递一个Bundle

  1. public Intent putExtra(String name, Bundle value) {
  2. if (mExtras == null) {
  3. mExtras = new Bundle();
  4. }
  5. mExtras.putBundle(name, value);
  6. return this;
  7. }

第三类:传递Serializable对象

  1. public Intent putExtra(String name, Serializable value) {
  2. if (mExtras == null) {
  3. mExtras = new Bundle();
  4. }
  5. mExtras.putSerializable(name, value);
  6. return this;
  7. }

第四类:Parcelable对象

  1. public Intent putExtra(String name, Parcelable value) {
  2. if (mExtras == null) {
  3. mExtras = new Bundle();
  4. }
  5. mExtras.putParcelable(name, value);
  6. return this;
  7. }
  8. public Intent putExtra(String name, Parcelable[] value) {
  9. if (mExtras == null) {
  10. mExtras = new Bundle();
  11. }
  12. mExtras.putParcelableArray(name, value);
  13. return this;
  14. }

第五类:Intent

  1. public Intent putExtras(Intent src) {
  2. if (src.mExtras != null) {
  3. if (mExtras == null) {
  4. mExtras = new Bundle(src.mExtras);
  5. } else {
  6. mExtras.putAll(src.mExtras);
  7. }
  8. }
  9. return this;
  10. }

归根结底都是通过Bundle来实现数据封装。而Bundle则是通过Map的数据结构来存储数据。

mMap = new HashMap<String, Object>();

mParcelledData

两者同时只有一个有效。

一旦unparcel以后,mParcelledData

的数据将被填充到mMap中,同时值为null。在writeToParcel和readFromParcel中则直接使用mParcelledData.此时一般通过IBinder关联两个进程的通信。

关于Bundle则是实现了Parcelable接口的类,通过上面提到的HashMap和一个Parcel来存储数据。

  1. public final class Bundle implements Parcelable, Cloneable {
  2. private static final String LOG_TAG = "Bundle";
  3. public static final Bundle EMPTY;
  4. static {
  5. EMPTY = new Bundle();
  6. EMPTY.mMap = Collections.unmodifiableMap(new HashMap<String, Object>());
  7. }
  8. // Invariant - exactly one of mMap / mParcelledData will be null
  9. // (except inside a call to unparcel)
  10. /* package */ Map<String, Object> mMap = null;
  11. /*
  12. * If mParcelledData is non-null, then mMap will be null and the
  13. * data are stored as a Parcel containing a Bundle.  When the data
  14. * are unparcelled, mParcelledData willbe set to null.
  15. */
  16. /* package */ Parcel mParcelledData = null;
    1. public void putFloat(String key, float value) {
    2. unparcel();//首先解析出mParcelledData到mMap
    3. mMap.put(key, value);
    4. }
    5. /* package */ synchronized void unparcel() {
    6. if (mParcelledData == null) {
    7. return;
    8. }
    9. int N = mParcelledData.readInt();
    10. if (N < 0) {
    11. return;
    12. }
    13. if (mMap == null) {
    14. mMap = new HashMap<String, Object>();
    15. }
    16. mParcelledData.readMapInternal(mMap, N, mClassLoader);
    17. mParcelledData.recycle();
    18. mParcelledData = null;//回收以后值为null
    19. }

Android:Intent传递数据的几种类型和源码实现的更多相关文章

  1. Android Intent传递数据

    刚开始看郭大神的<>,实现以下里面的一些例子.Intent传递数据. 我们利用显示的方式进行Intent的启动. 1.启动intent并输入数据. Intent intent=new In ...

  2. Android Intent 传递数据注意事项

    不要通过 Intent 在 Android 基础组件之间传递大数据(binder transaction缓存为 1MB),可能导致 OOM.

  3. 【转】Android 之最新最全的Intent传递数据方法

    原文地址:https://www.jianshu.com/p/1169dba99261 intent传递数据 为什么要和intent单独拿出来讲,因为Intent传递数据也是非常重要的 一.简单的传递 ...

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

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

  5. Android 开发中使用Intent传递数据的方法

    Activity之间通过Intent传递值,支持基本数据类型和String对象及 它们的数组对象byte.byte[].char.char[].boolean.boolean[].short.shor ...

  6. Android学习之Intent传递数据

    Intent在Activity中的作用主要是有两个: 1.启动目标Activity 2.传递数据 Intent在传递数据时分两种情况:向下一个Activity传递数据和从下一个Activity返回数据 ...

  7. Android Activity传递数据使用getIntent()接收不到,揭秘Intent传递数据与Activity启动模式singleTask的关系。

    activity通过intent传递数据的时候,如果activity未启动,那么在这个刚启动的activity里通过getIntent()会获取到这个intent的数据.. 如果要启动的activit ...

  8. 安卓通过putExtra传递数据的几种方式

    通过intent传递数据时,使用以下代码报错: hMap<string, object=""> map=(Map<string, object="&qu ...

  9. Intent传递对象的几种方式

    原创文章.转载请注明 http://blog.csdn.net/leejizhou/article/details/51105060 李济洲的博客 Intent的使用方法相信你已经比較熟悉了,Inte ...

随机推荐

  1. OpenGL-选择与拾取

    转自:http://blog.sina.com.cn/s/blog_4a9aa55c0100vu57.html 以下内容主要整理<OpenGL编程指南>第13章的内容.主要解决以下问题: ...

  2. Android界面实现----PagerTabStrip绚丽的滑动标签

    在ViewPager这种可以滑动的控件上,总是有很多的文章可以做.Android自带的控件,实现一个指示器,这个控件,就是support-v4包里面的PagerTabStrip控件. 首先,我们先看一 ...

  3. Netty中BIO,NIO

    同步阻塞io(BIO).伪异步io(PIO).非阻塞io(NIO).异步io(AIO)的概念及区别? 同步阻塞io(BIO):服务器端与客户端通过三次握手后建立连接,连接成功,双方通过I/O进行同步阻 ...

  4. 第七篇 Replication:合并复制-订阅

    本篇文章是SQL Server Replication系列的第七篇,详细内容请参考原文. 订阅服务器就是复制发布项目的所有变更将传送到的服务器.每一个发布需要至少一个订阅,但是一个发布可以有多个订阅. ...

  5. C#开发ActiveX插件-aspx中嵌入

    刚到新的公司,第一周让我熟悉一下他们用的silverlight和arcgis.这周,也就是昨天分配了我一个小小的任务! 哪个项目的不知道,是让我实现一个在aspx中嵌入activeX插件! 在网上找了 ...

  6. NET4.5之初识async与await

    这是两个关键字,用于异步编程.我们传统的异步编程方式一般是Thread.ThreadPool.BeginXXX.EndXXX等等.把调用.回调分开来,代码的逻辑是有跳跃的,于是会导致思路不是很清晰的问 ...

  7. 错误是无法将“XXX”转换为“System.CompenentModel.Design.Serialization.InstanceDescrip”问题的解决办法

    发生原因: 出现这个问题的原因是两次编译生成的程序集的版本一样,导致VS的窗体设计器没有获取到最新的运行时对象,而出现的错误. 解决办法: 修改项目的配置信息,使其每次编译的时候都生成不同的版本. 在 ...

  8. networkcommon v3开源消息框架资料

    http://www.cnblogs.com/csdev/category/870400.html

  9. 错过C++

    曾相识的C++--2008年那是还在学校,接触到了这门语言,可遗憾的是当时,自己没有能静下心好好学习这门语言.所以相识了了半年的c++就这样不见. 如今又相逢,但已经感觉到很陌生,陌生的我们互补相认.

  10. iOS6:在你的企业系统中支持Passbook

    前言 这是一篇翻译,感谢Jonathan Tang. 原文地址:iOS 6 Tutorial: Supporting Passbook within Your Enterprise Systems 正 ...