Intent传递对象——Serializable和Parcelable区别
2016-06-18 17:02
302 查看
Intent在不同的组件中传递对象数据的应用非常普遍。下面介绍两种通过Intent传递对象的方法。
1、实现Serializable接口
2、实现Parcelable接口
为什么要将对象序列化?
1、永久性保存对象,保存对象的字节序列到本地文件中;
2、用过序列化对象在网络中传递对象;
3、通过序列化对象在进程间传递对象。
1、实现Serializable接口
Serializable的作用是将数据对象存入字节流当中,在需要时重新生成对象,主要应用是利用外部存储设备保存对象状态,以及通过网络传输对象等。
implements Serializable接口的的作用就是给对象打了一个标记,系统会自动将其序列化。
案例:
class Elephant implements Serializable{
private static final long serialVersionUID = 7958956482228421832L;
private String name;
public Elephant(String name) {
this.name=name;
}
@Override
public String toString() {
return name;
}
}
//在某一activity的方法中执行
intent.putExtra("key03",
new Elephant("EA01"));
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的对象实在内存中完成的序列化和反序列化,利用的是连续的内存空间,因此更加高效。
注意:写对象属性和读对象属性的顺序必须一致。如果不一致,在得到intent的数据时会出现空的属性。
案例:
步骤1:自定义实体类,实现Parcelable接口,重写其两个方法。
步骤2:该实体类必须添加一个常量CREATOR(名字大小写都不能使其他的),该常量必须实现Parcelable的内部接口:Parcelable.Creator,并实现该接口中的两个方法。
class Student implements Parcelable{
String name;
int age;
public Student(String name,int age){
this.name=name;
this.age=age;
}
public Student(Parcel in){
//读对象的属性
this.name=in.readString();
this.age=in.readInt();
}
@Override
public String toString() {
return "Student [name=" + name + ", age=" + age + "]";
}
@Override
public int describeContents() {
// TODO Auto-generated method stub
return 1; //此方法的意义暂时未知,但不影响对象的获取
}
@Override
public void writeToParcel(Parcel dest, int flags) {
//写对象的属性
dest.writeString(name);
dest.writeInt(age);
}
public static final Parcelable.Creator<Student> CREATOR = new Parcelable.Creator<Student>() {
public Student createFromParcel(Parcel in) {
return new Student(in);
}
public Student[] newArray(int size) {
return new Student[size];
}
};
}
//在某一activity的方法中执行
intent.putExtra("key04",
new Student("stu-a",18));
//在其他activity中拿到intent传递的对象
Intent intent=getIntent();
Student stu=intent.getParcelableExtra("key04");
1、实现Serializable接口
2、实现Parcelable接口
为什么要将对象序列化?
1、永久性保存对象,保存对象的字节序列到本地文件中;
2、用过序列化对象在网络中传递对象;
3、通过序列化对象在进程间传递对象。
1、实现Serializable接口
Serializable的作用是将数据对象存入字节流当中,在需要时重新生成对象,主要应用是利用外部存储设备保存对象状态,以及通过网络传输对象等。
implements Serializable接口的的作用就是给对象打了一个标记,系统会自动将其序列化。
案例:
class Elephant implements Serializable{
private static final long serialVersionUID = 7958956482228421832L;
private String name;
public Elephant(String name) {
this.name=name;
}
@Override
public String toString() {
return name;
}
}
//在某一activity的方法中执行
intent.putExtra("key03",
new Elephant("EA01"));
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的对象实在内存中完成的序列化和反序列化,利用的是连续的内存空间,因此更加高效。
注意:写对象属性和读对象属性的顺序必须一致。如果不一致,在得到intent的数据时会出现空的属性。
案例:
步骤1:自定义实体类,实现Parcelable接口,重写其两个方法。
步骤2:该实体类必须添加一个常量CREATOR(名字大小写都不能使其他的),该常量必须实现Parcelable的内部接口:Parcelable.Creator,并实现该接口中的两个方法。
class Student implements Parcelable{
String name;
int age;
public Student(String name,int age){
this.name=name;
this.age=age;
}
public Student(Parcel in){
//读对象的属性
this.name=in.readString();
this.age=in.readInt();
}
@Override
public String toString() {
return "Student [name=" + name + ", age=" + age + "]";
}
@Override
public int describeContents() {
// TODO Auto-generated method stub
return 1; //此方法的意义暂时未知,但不影响对象的获取
}
@Override
public void writeToParcel(Parcel dest, int flags) {
//写对象的属性
dest.writeString(name);
dest.writeInt(age);
}
public static final Parcelable.Creator<Student> CREATOR = new Parcelable.Creator<Student>() {
public Student createFromParcel(Parcel in) {
return new Student(in);
}
public Student[] newArray(int size) {
return new Student[size];
}
};
}
//在某一activity的方法中执行
intent.putExtra("key04",
new Student("stu-a",18));
//在其他activity中拿到intent传递的对象
Intent intent=getIntent();
Student stu=intent.getParcelableExtra("key04");
相关文章推荐
- 团队总结
- innodb结构解析工具---innodb_ruby
- Win7系统资源管理器加上预览窗格功能的方法
- 差之毫厘谬以千里,要认真才好
- guava Splitter
- guava Function Predicate Supplier
- Android:正常情况下的Activity的生命周期
- guava 常用对象方法
- guava Joiner
- Android 利用内容观察者实现短信窃听
- android-----XUtils框架之HttpUtils源码分析
- 通过Dmgr管理界面添加Web服务器定义
- ubuntu添加开机自启动程序
- 【知识积累】Entity Framework学习:POCO延迟加载
- 《javascript代码规范整理》
- 4、eclipse开发web的教程
- guava Optional
- Eclipse关联android-support-v7.jar查看源码
- 利用vue.js把静态json绑定bootstrap的table
- ios 开发file's owner以及outlet与连线的理解