首页 Android Intent传递对象——Serializable和Parcelable区别

Intent传递对象——Serializable和Parcelable区别

Intent在不同的组件中传递对象数据的应用非常普遍。下面介绍两种通过Intent传递对象的方法。 1、实现Serial…

Intent在不同的组件中传递对象数据的应用非常普遍。下面介绍两种通过Intent传递对象的方法。

1、实现Serializable接口

2、实现Parcelable接口

 

为什么要将对象序列化?

1、永久性保存对象,保存对象的字节序列到本地文件中;

2、用过序列化对象在网络中传递对象;

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

 

1、实现Serializable接口

Serializable的作用是将数据对象存入字节流当中,在需要时重新生成对象,主要应用是利用外部存储设备保存对象状态,以及通过网络传输对象等。

implements Serializable接口的的作用就是给对象打了一个标记,系统会自动将其序列化。

 

    案例1:

 1)User.java  (implements Serializable )

 2)MainActivity.java  

User user = new User();

Intent intent = new Intent(this,Second.class);

intent.putExtra(“user”,user);

 3)Second.java

Intent intent = getIntent();

User user = intent.getSerializableExtra(“user”);

 

2、实现Parcelable接口

     1)为什么要实现Parfcelable接口来实现在Intent中传递对象?

a、在使用内存的时候,Parcelable比Serializable性能高,所以推荐使用Parcelable类。

b、Serializable在序列化的时候会产生大量的临时变量,从而引起频繁的GC。

 

     注意:Parcelable不能使用在将数据存储在磁盘上的情况,因为Parcelable不能很好的保存数据的持续性在外界有变化的情况下。因此在这种情况下,建议使用Serializable

      

     2) Android中的新的序列化机制

在Android系统中,针对内存受限的移动设备,因此对性能要求更高,Android系统采用了新的IPC(进程间通信)机制,要求使用性能更出色的对象传输方式。因此Parcel类被设计出来,其定位就是轻量级的高效的对象序列化和反序列化机制。

Parcel的序列化和反序列化的读写全是在内存中进行,所以效率比JAVA序列化中使用外部存储器会高很多。

 

Parcel类

就应用程序而言,在常使用Parcel类的场景就是在Activity间传递数据。在Activity间使用Intent传递数据的时候,可以通过Parcelable机制传递复杂的对象。

Parcel机制:本质上把它当成一个Serialize就可以了。只是Parcel的对象实在内存中完成的序列化和反序列化,利用的是连续的内存空间,因此更加高效。

 

案例:

    步骤1:自定义实体类,实现Parcelable接口,重写其两个方法。

    步骤2:该实体类必须添加一个常量CREATOR(名字大小写都不能使其他的),该常量必须实现Parcelable的内部接口:Parcelable.Creator,并实现该接口中的两个方法。

User.java如下:

package com.example.intent_object;

import android.os.Parcel;
import android.os.Parcelable;

public class User implements Parcelable {
    public String name;
    public int age;

    // 必须要创建一个名叫CREATOR的常量。
    public static final Parcelable.Creator<User> CREATOR = new Parcelable.Creator<User>() {
        @Override
        public User createFromParcel(Parcel source) {
            return new User(source);
        }
        //重写createFromParcel方法,创建并返回一个获得了数据的user对象
        @Override
        public User[] newArray(int size) {
            return new User[size];
        }
    };

    @Override
    public String toString() {
        return name + ":" + age;
    }

    // 无参数构造器方法,供外界创建类的实例时调用
    public User() {
    }

    // 带参构造器方法私用化,本构造器仅供类的方法createFromParcel调用
    private User(Parcel source) {
        name = source.readString();
        age = source.readInt();
    }

    @Override
    public int describeContents() {
        return 0;
    }

    // 将对象中的属性保存至目标对象dest中
    @Override
    public void writeToParcel(Parcel dest, int flags) {
        dest.writeString(name);
        dest.writeInt(age);
    }

  //省略getter/setter }

 

其他代码:

Java代码
Bundle bundle = new Bundle();
                    bundle.putParcelable("user", user);
                    Intent intent = new Intent(MainActivity.this,
                            SecondActivity.class);
                    intent.putExtras(bundle);

 

Intent intent = getIntent();
        Bundle bun = intent.getExtras();
        User user = bun.getParcelable("user");
        System.out.println(user);

 

免责声明:文章内容不代表本站立场,本站不对其内容的真实性、完整性、准确性给予任何担保、暗示和承诺,仅供读者参考,文章版权归原作者所有。如本文内容影响到您的合法权益(内容、图片等),请及时联系本站,我们会及时删除处理。

为您推荐

android studio查看android手机日志

android studio查看android手机日志

本文在尝试了,使用adb,eclipse查看log未果之后,使用android studio来查看unity打包的apk...
Conversion to Dalvik format failed: Unable to execute dex: java.nio.BufferOverflowException. Check t

Conversion to Dalvik format failed: Unable to execute dex: java.nio.BufferOverflowException. Check t

在android高版本开发环境(sdk 4.4)导入低版本(sdk 3.0)的工程时编译报错,报错信息如:Convers...
用Bundle和直接用Intent.putExtra(“xx”,yy)传递有什么不同

用Bundle和直接用Intent.putExtra(“xx”,yy)传递有什么不同

QQ群里一个提出来了 。。长知识了。。 Intent intent = new Intent(); intent.put...
Universal-Image-Loader解析——DisplayImageOptions的详细配置

Universal-Image-Loader解析——DisplayImageOptions的详细配置

在使用这个框架的时候,我们必须要配置一个DisplayImageOptions对象来作为ImageLoader.getI...
安卓测试环境的配置

安卓测试环境的配置

AndroidManifest.xml 配置 <uses-permission android:name="and...
返回顶部