安卓实现序列化之Parcelable接口

1.实现序列化的方法:

Android中实现序列化有两个选择:一是实现Serializable接口(是JavaSE本身就支持的)

。一是实现Parcelable接口(是Android特有功能,效率比实现Serializable接口高效,可用

于Intent数据传递。也能够用于进程间通信(IPC))。实现Serializable接口很easy。声

明一下就能够了,而实现Parcelable接口略微复杂一些。但效率更高,推荐用这样的方法提高性能。

注:Android中Intent传递对象有两种方法:一是Bundle.putSerializable(Key,Object)。还有一种是

Bundle.putParcelable(Key,Object)。

当然这些Object是有一定的条件的,前者是实现了Serializable

接口,而后者是实现了Parcelable接口。

2.为什么要实现序列化?

永久性保存对象,保存对象的字节序列到本地文件里;通过序列化对象在网络中传递对象;

通过序列化在进程间传递对象。

3.选择序列化方法的原则

1)在使用内存的时候。Parcelable比Serializable性能高。所以推荐使用Parcelable。

2)Serializable在序列化的时候会产生大量的暂时变量,从而引起频繁的GC。

3)Parcelable不能使用在要将数据存储在磁盘上的情况,由于Parcelable不能非常好的保证

数据的持续性在外界有变化的情况下。虽然Serializable效率低点,但此时还是建议使

用Serializable 。

4.应用场景:

须要在多个部件(Activity或Service)之间通过Intent传递一些数据,简单类型(如:数字、

字符串)的能够直接放入Intent。复杂类型必须实现Parcelable接口。

5.Parcelable接口定义

public interface Parcelable
{
    //内容描写叙述接口,基本不用管
    public int describeContents();

//写入接口函数,打包
    public void writeToParcel(Parcel dest, int flags);

//读取接口,目的是要从Parcel中构造一个实现了Parcelable的类的实例处理。由于

实现类在这里还是不可知的,所以须要用到模板的方式。继承类名通过模板參数传入。
    //为了可以实现模板參数的传入,这里定义Creator嵌入接口,内含两个接口函数分别

返回单个和多个继承类实例。

public interface Creator<T>
{
           public T createFromParcel(Parcel source);

public T[] newArray(int size);
}
}

6.实现Parcelable步骤

1)implements Parcelable

2)重写writeToParcel方法,将你的对象序列化为一个Parcel对象,即:将类的数据写入

外部提供的Parcel中,打包须要传递的数据到Parcel容器保存,以便从 Parcel容器获取数据

3)重写describeContents方法。内容接口描写叙述,默认返回0就能够

4)实例化静态内部对象CREATOR实现接口Parcelable.Creator

public static final Parcelable.Creator<T> CREATOR

注:当中public static final一个都不能少。内部对象CREATOR的名称也不能改变,

必须所有大写。需重写本接口中的两个方法:createFromParcel(Parcel in) 实现从

Parcel容器中读取传递数据值,封装成Parcelable对象返回逻辑层,newArray(int size)

创建一个类型为T。长度为size的数组。仅一句话就可以(return new T[size]),供外部

类反序列化本类数组使用。

简而言之:通过writeToParcel将你的对象映射成Parcel对象,再通过createFromParcel

将Parcel对象映射成你的对象。

也能够将Parcel看成是一个流,通过writeToParcel把对象

写到流里面,在通过createFromParcel从流里读取对象,仅仅只是这个过程须要你来实现,

因此写的顺序和读的顺序必须一致。

代码例如以下:

public class MyParcelable implements Parcelable

{
     private int mData;

public int describeContents() 
     {
         return 0;
     }

public void writeToParcel(Parcel out, int flags) 
     {
         out.writeInt(mData);
     }

public static final Parcelable.Creator<MyParcelable> CREATOR = new Parcelable.Creator<MyParcelable>() 
     {
         public MyParcelable createFromParcel(Parcel in) 
         {
             return new MyParcelable(in);
         }

public MyParcelable[] newArray(int size) 
         {
             return new MyParcelable[size];
         }
     };
     
     private MyParcelable(Parcel in) 
     {
         mData = in.readInt();
     }
 }

7.Serializable实现与Parcelabel实现的差别

1)Serializable的实现。仅仅须要implements  Serializable 就可以。这仅仅是给对象打

了一个标记。系统会自己主动将其序列化。

2)Parcelabel的实现,不仅须要implements  Parcelabel,还须要在类中加入一个

静态成员变量CREATOR。这个变量须要实现 Parcelable.Creator 接口。

两者代码比較:

1)创建Person类,实现Serializable

public class Person implements Serializable
{
    private static final long serialVersionUID = -7060210544600464481L;

private String name;

private int age;
    
    public String getName()
    {
        return name;
    }
    
    public void setName(String name)
    {
        this.name = name;
    }
    
    public int getAge()
    {
        return age;
    }
    
    public void setAge(int age)
    {
        this.age = age;
    }
}

2)创建Book类,实现Parcelable

public class Book implements Parcelable
{
    private String bookName;

private String author;

private int publishDate;
    
    public Book()
    {
        
    }
    
    public String getBookName()
    {
        return bookName;
    }
    
    public void setBookName(String bookName)
    {
        this.bookName = bookName;
    }
    
    public String getAuthor()
    {
        return author;
    }
    
    public void setAuthor(String author)
    {
        this.author = author;
    }
    
    public int getPublishDate()
    {
        return publishDate;
    }
    
    public void setPublishDate(int publishDate)
    {
        this.publishDate = publishDate;
    }
    
    @Override
    public int describeContents()
    {
        return 0;
    }
    
    @Override
    public void writeToParcel(Parcel out, int flags)
    {
        out.writeString(bookName);

out.writeString(author);

out.writeInt(publishDate);
    }
    
    public static final Parcelable.Creator<Book> CREATOR = new Creator<Book>()
    {
        @Override
        public Book[] newArray(int size)
        {
            return new Book[size];
        }
        
        @Override
        public Book createFromParcel(Parcel in)
        {
            return new Book(in);
        }
    };
    
    public Book(Parcel in)
    {
        bookName = in.readString();

author = in.readString();

publishDate = in.readInt();
    }
}

转载于:https://www.cnblogs.com/lytwajue/p/7098094.html

安卓实现序列化之Parcelable接口相关推荐

  1. Android --- Serializable 接口与 Parcelable 接口的使用方法和区别,怎么选择?

    文章目录 一.前言: 二.Serializable 接口 三.Parcelable 接口 四.两种接口怎么选择 一.前言: 本节主要讲解 IPC 中的基本概念,Serializable 接口与 Par ...

  2. Serializable接口和Parcelable接口

    一.Serializable接口 在Java中,一般在定义实体类(entity class)时,会去实现Serializable接口,下面举例: 重点: 使用Serializable接口很简单,只需要 ...

  3. Android中Parcelable接口用法

    --  通过writeToParcel将你的对象映射成Parcel对象,再通过createFromParcel将Parcel对象映射成你的对象.也可以将Parcel看成是一个流,通过writeToPa ...

  4. Android中的数据传递之Parcelable接口

    对于Android来说传递复杂类型,主要是将自己的类转换为基础的字节数组,Activity之间传递数据是通过Intent实现的. Android序列化对象主要有两种方法,实现Serializable接 ...

  5. Android 的Parcelable接口

    此文转载自http://www.cnblogs.com/renqingping/archive/2012/10/25/Parcelable.html 1. Parcelable接口 Interface ...

  6. Android中的Parcelable接口和Serializable用法和区别

    Parcelable接口: Interface for classes whose instances can be written to and restored from a Parcel. Cl ...

  7. android 如何使用Parcelable接口

    今天,简单讲讲android如何使用Parcelable接口传递数据. 这个其实也很简单,之前我写过博客将关于Serializable接口传递对象,实现Parcelable接口也是为了传递对象,但效率 ...

  8. android 传递接口对象吗,android中Intent传递对象,需要实现Serializable接口或者Parcelable接口...

    Intent传递对象,有两种方法 1. 实现Serializable接口 类要生成序列化ID,并且不能是内部类 2. 实现Parcelable接口 参照Parcelable的doc文档 实现Seria ...

  9. android 序列化传参数,Android序列化之Parcelable和Serializable的使用详解

    序列化与反序列 首先来了解一下序列化与反序列化. 序列化 由于存在于内存中的对象都是暂时的,无法长期驻存,为了把对象的状态保持下来,这时需要把对象写入到磁盘或者其他介质中,这个过程就叫做序列化. 反序 ...

最新文章

  1. Apollo分布式配置中心在本地的安装教程
  2. 这份HCIE-Routing Switching笔试试题,你能答对几道?
  3. C宏定义中的##,#,#@用法介绍
  4. java8 b计算时间差_java8-计算时间差的方法
  5. nginx stream代理
  6. (十四)java版spring cloud+spring boot 社交电子商务平台-使用spring cloud Bus刷新配置...
  7. Python NLP英文文本转小写
  8. 计算机nit证书怎么学,计算机等级考试证书和NIT可以抵免自考中哪些课程?
  9. 实习笔试题,源代码编译
  10. idea给main方法附带参数
  11. 预处理、const、static与sizeof-static全局变量与普通的全局变量有什么区别
  12. python把int转为str_python中int与str互转方法
  13. 服务器安全(防止被攻击)
  14. 使用ADSL拨号服务器搭建自己的代理IP
  15. linux 下 格式化u盘 并分区 为fat32文件系统
  16. Android关于透明度对应表
  17. 超级准确的Android/JAVA面试题合集,背会你就10k!
  18. Linux中mysql的重启
  19. DICOM:基于DCMTK实现C-FIND SCU
  20. python中登录基金账户获取基金数据

热门文章

  1. impacket安装 python_Impacket网络协议工具包介绍
  2. iphone11什么时候上市_hd3手表高仿哪里买 什么时候上市?
  3. springcloud官方文档_通俗易懂!Spring Cloud简介:官方文档翻译版
  4. 【安卓开发 】Android初级开发(七)MD5加密
  5. java 实例对象拷贝,实例详解java对象拷贝
  6. centos7.4编译mysql5.6,centos7编译安装mysql5.6
  7. 每台计算机需要配置网关吗,每台计算机的IP地址和网关以及子网掩码的设置有哪些规律或者规则吗?...
  8. python mysql操作_Python的MySQL操作
  9. 敲代码时如何快速移动光标_如何用 Linux 技巧大大提高工作效率?
  10. ubuntu的home目录下,Desktop等目录消失不见