- 浏览: 559162 次
- 性别:
- 来自: 武汉
文章分类
最新评论
-
北月与南安:
哥哥不要秀我,答案是11.38,你算出来36.43,要求N个点 ...
平均距离 -
xiao_android_jun:
[color=red][ size=xx-small ...
Android 之 进程的概念介绍 -
明子健:
小伙子,很有前途哦
《将博客搬至CSDN》 -
1140566087:
dugujiujian 写道R.layout.simple_s ...
Android 之 下拉(Spinner) 组件示例 -
dugujiujian:
R.layout.simple_spinner_dropdow ...
Android 之 下拉(Spinner) 组件示例
/* 序列化 * * 作用:序列化是为了保存在内存中的各种对象的状态(也就是实例变量,不是方法), * 并且可以把保存的对象状态再读出来。即:序列化是一种能比较好的保存对象状态 * 的机制; * * 优点: * 1、永久性的保存对象,保存对象的字节序列到本地文件中; * 2、通过序列化对象在网络中传递对象; * 3、通过序列化在进程中传递对象; * * 序列化方法: * 1、实现Serializable 接口 ---- JAVA SE 本身支持的; * 2、实现Parcelable 接口 ---- Android 特有的功能,效率比前者的高 * * 选取序列化方法的原因: * 1、在使用内存的时候,Parcelable 类比 Serializable 性能高; * 2、Serializable 在序列化的时候会产生大量的临时变量,从而引起频繁的GC; * 3、Parcelable 不能使用在要将数据储存在磁盘上的情况,因为Parcelable 不 * 能很好的保证数据的持续性,在外界有变化的情况下; * * 使用方法: * 1、Serializable 的实现,只需要实现Serializable 这个接口就行,系统会自动的序列化; * 2、Parcelable 序列化实现: * a、声明实现接口Parcelable * b、实现Parcelable 的方法 writeToParcel ,将你的对象序列化为一个Parcel对象; * c、实例化静态内部对象CREATOR,实现接口 Parcelable.Creator * public static final Parcelable.Creator<T> CREATOR ,注意:public static * final 一个不能少,内部对象CREATOR 的名称也不能改变,必须全部大写; * d、完成了CREATOR 的代码,实现方法createFromParcel ,将 Parcel 对象反序列化为你的对象; * * 提示:通过writeToParcel 将你的对象映射成Parcel 对象,再通过createFromParcel将 * parcel映射成你的对象,也可以将Parcel看成是一个流,通过writeToParcel 把对象写到 * 流里面,在通过createFromParcel 把对象从流里面读取对象,只不过这个过程需要自己来实现, * 因此写的顺序和读的顺序必须一致; * * 3、支持的数据类型:byte double float int long String 六种; 以及他们的数组; * * */ 使用ParcelableData 序列化数据并进行传递: package com.sun.parcelable; import android.os.Parcel; import android.os.Parcelable; import android.util.Log; public class ParcelableData implements Parcelable { private String name; private String[] names; private int age; private float score; private double money; private byte file; // -128 -127 private long longname; //构造方法 public ParcelableData(String name, String[] names, int age, float score, double money, byte file, long longname) { super(); this.name = name; this.names = names; this.age = age; this.score = score; this.money = money; this.file = file; this.longname = longname; } public String[] getNames() { return names; } public void setNames(String[] names) { this.names = names; } public ParcelableData(){} 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; } public float getScore() { return score; } public void setScore(float score) { this.score = score; } public double getMoney() { return money; } public void setMoney(double money) { this.money = money; } public byte getFile() { return file; } public void setFile(byte file) { this.file = file; } public long getLongname() { return longname; } public void setLongname(long longname) { this.longname = longname; } // 内容描述接口 , 默认返回 0 就可以了 public int describeContents() { return 0; } // 读取接口,将 对象 序列化成 Parcel public void writeToParcel(Parcel dest, int flags) { Log.i("msg","writeToParcel() 进来了,准备开始对象序列化...."); dest.writeString(name); dest.writeInt(age); dest.writeByte(file); dest.writeLong(longname); dest.writeDouble(money); dest.writeFloat(score); dest.writeStringArray(names); Log.i("msg","writeToParcel() 序列化完成,即将退出..."); } /** * 实例化静态内部对象CREATOR ,该对实现接口Parcelable.Creator * 注意:public static final 一个都不能少,内部对象名称CREATOR 不能变,必须为大写 */ public static final Parcelable.Creator<ParcelableData> CREATOR = new Creator<ParcelableData>() { // 将 Parcel 对象 反序列化为对象 public ParcelableData createFromParcel(Parcel source) { Log.i("msg","createFromParcel() 进来了,准备开始反序列化...."); ParcelableData pd = new ParcelableData(); pd.setName(source.readString()); pd.setAge(source.readInt()); pd.setFile(source.readByte()); pd.setLongname(source.readLong()); pd.setMoney(source.readDouble()); pd.setScore(source.readFloat()); // 反序列 数组 pd.setNames(source.createStringArray()); Log.i("msg","createFromParcel() 反序列化完成,即将退出,返回对象...."); return pd; } public ParcelableData[] newArray(int size) { return null; } }; }
发送序列化的数据:
package com.sun.parcelable; import android.os.Bundle; import android.app.Activity; import android.content.Intent; import android.util.Log; import android.view.Menu; public class MainActivity extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); // 携带数据跳转 并显示 Intent intent = new Intent(); intent.setClass(MainActivity.this, SecondActivity.class); ParcelableData pd = new ParcelableData(); pd.setAge(12); pd.setFile(Byte.parseByte("123")); // -128 --- 127 pd.setLongname(54455); pd.setMoney(11.001); pd.setName("卫斯理"); pd.setNames(new String[]{"numbe1","number2"}); pd.setScore(23.2f); Bundle bundle = new Bundle(); Log.i("msg", "Bundle对象初始化完成,马上进入putParcelable 操作...."); bundle.putParcelable("pd",pd); Log.i("msg","putParcelable() 存入数据完成....Intent 准备带入数据..."); intent.putExtras(bundle); Log.i("msg","intent.putExtras(bundle) 完成...马上开始跳转..."); startActivity(intent); Log.i("msg","跳转中...."); } }
接收数据:
package com.sun.parcelable; import android.app.Activity; import android.content.Intent; import android.os.Bundle; import android.util.Log; import android.widget.EditText; public class SecondActivity extends Activity{ protected void onCreate(Bundle savedInstanceState) { // TODO Auto-generated method stub super.onCreate(savedInstanceState); setContentView(R.layout.secondactivity_layout); EditText show = (EditText) findViewById(R.id.show); Log.i("msg","开始获得传递过来的相关数据 , Intent bundle ...."); Intent intent = getIntent(); Bundle bundle = intent.getExtras(); Log.i("msg","Intent对象获取完毕,下一步获取ParcelableData对象...."); ParcelableData pd = bundle.getParcelable("pd"); Log.i("msg","ParcelableData 对象获取完毕,下一步显示"); show.setText(pd.getAge()+"\n"+""+pd.getFile()+"\n"+pd.getLongname()+"\n"+pd.getMoney()+"\n"+pd.getName()+"\n"+pd.getScore()+"\n"+pd.getNames().length); } }
- parcelable.rar (928.8 KB)
- 下载次数: 3
发表评论
-
Android 之 网络访问服务器,解析JSON数据
2014-03-28 22:50 3415提示:在访问网络,或者服务器的数据一定要注意 网络权限的声明: ... -
Android 之 AsyncTask 异步任务
2014-03-20 08:44 3522Android ... -
Android 之 Looper Handler Message 之间的关系
2014-03-19 10:16 3665Android 的消息 ... -
Android 之 多线程与Socket联合使用案例
2014-03-19 10:15 2673多线 ... -
Android 之 多线程和Socket套接字的使用介绍
2014-03-19 10:15 4884And ... -
Android 之 实现Runnable 接口与继承Thread的区别
2014-03-19 10:15 2199实现Runnable 接口 相 ... -
Android 之 GSON解析JSON数据
2014-03-19 10:14 4490... -
Android 之 使用Pull 解析xml文件
2014-03-18 21:04 1045/** * 使用Pull进行 xml 文件的解析 ... -
Android 之 使用DOM解析xml文件
2014-03-18 21:02 2745DOM 解析 xml 格式的文件 1、 xml简介:xml ... -
Android 之 百度API 密钥安全码生成
2014-03-04 22:29 2413近期要做个关于旅游助手的应用,开始接触百度API了。大神们 ... -
Android 之 EditText属性用法介绍
2014-01-06 23:49 3991EditText的属性 EditText继承关系:View-- ... -
Android 之 自定义适配器
2014-01-08 10:40 1775自定义适配器 1、实现 * 自定义适配器要继承 BaseA ... -
Android 之 自定义控件用法介绍
2014-01-08 10:40 1720自定义效果:实现:图片和文字混合 首先创建需要组合的子布局: ... -
Android 之 资源自适应与国际化
2014-01-08 10:40 3081<!-- 国际化和资源自适应 ... -
Android 之 五大布局案例
2014-01-08 10:41 21331、LinearLayout 线性布局例子: <Lin ... -
Android 之 通知Notification
2014-03-03 22:30 3897Notification 和 NotificationMana ... -
Android 之 手机全屏显示
2014-03-03 22:30 2344/* 1、全屏状态的显示 介绍:Android 中提供了Wi ... -
Android 之 拦截手机短信并自动转发
2014-03-03 22:29 5436拦截短信和发送短信都需要相关的权限: <?xml ve ... -
Android 之 将RAW资源文件写入SD卡工具类
2014-03-01 10:09 3615package com.sun.coptfiletosd; ... -
Android 之 监控手机电量
2014-03-01 10:09 1797package com.example.battery; ...
相关推荐
标题"Android Parcelable序列化自定义类集合在Activity间传递"所涉及的知识点主要集中在以下几个方面: 1. **Parcelable接口**: `Parcelable`是Android提供的一个接口,用于对象的序列化和反序列化。通过实现这个...
Android开发中的Parcelable接口是用于对象序列化的一种高效方式,它比Java自带的Serializable接口性能更好,但编写起来较为繁琐。`android-parcelable-intellij-plugin`是一个IntelliJ IDEA的插件,它可以帮助开发者...
在Android中用Parcelable序列化虽然效率高,但是比Serializable麻烦很多;现在只要添加一个Jar包就可以省去序列化的过程,很方便。 Jar包在项目里,可以直接使用,也可以查看里面的文本文件"README.md
Parcelable是Android特有的序列化方式,相比Serializable,它的性能更好,但是实现较为复杂。你需要手动编写序列化和反序列化的代码,使用`writeToParcel()`和`Creator`接口。 优点: - 性能高效,Parcelable比...
`Parcelable`是Android系统提供的一种高效的数据序列化方式,相比Java的`Serializable`接口,它的性能更优,因为`Parcelable`在序列化和反序列化时提供了更直接的内存操作。本篇文章将详细探讨`Parcelable`在Android...
Android提供了两种主要的序列化方式:Parcelable和Serializable。这两种方式都可以将对象转换为字节流,便于存储、传输或恢复。下面将详细讨论Android通过Parcelable和Serializable实现各种类型嵌套序列化的方法。 ...
Android提供了两种主要的序列化方式:`Serializable` 和 `Parcelable`。 1. **序列化的目的** - 永久保存对象数据:对象的状态可以被保存到文件或数据库,以便在以后恢复。 - 网络传输:通过将对象转换为字节流,...
Android提供了两种主要的序列化方式:`Serializable`和`Parcelable`。本文将深入探讨`Parcelable`,它是Android平台中效率更高的序列化接口。 **一、Parcelable简介** `Parcelable`是Android系统提供的一个接口,...
在Android中,Parcelable是数据序列化的高级接口,它比Serializable效率更高。如果要在AIDL中传递自定义对象,这些对象必须实现Parcelable接口。实现Parcelable接口通常包括以下步骤: 1. 创建一个内部静态类`...
Parcelable序列化是Android中的一种数据序列化方式,用于将对象转换为Parcel,以便在不同的Activity或者Service之间传输数据。在Kotlin中,我们可以使用Parcelable接口来实现序列化。例如: ```kotlin data class ...
在Android开发过程中,我们常常需要实现Parcelable接口来方便对象的序列化和反序列化,以便于在Intent、Binder等场景中传递数据。然而,手动实现Parcelable接口的代码繁琐且容易出错。为此,开发者们创建了一个名为...
**Parcelable序列化** Parcelable是Android平台提供的一种高效的序列化方式,它是专门为Android系统设计的,相比Serializable效率更高。Parcelable接口位于`android.os`包下,是Android特有的序列化方式。实现...
本文将深入探讨Android中两种主要的序列化方式:Serializable和Parcelable,并解析它们的工作原理及优缺点。 首先,我们来了解Serializable接口。Serializable是Java提供的一个标准序列化接口,任何实现了此接口的...
而Parcelable是Android平台提供的一种高效的数据序列化机制,相比Java内置的Serializable接口,它在性能上更优,更适合在进程间传递数据或者保存数据到内存中。本篇文章将详细解释Android序列化过程中的Parcelable...
示例app
`Parcelable`接口是Android系统提供的一种高效的对象序列化机制,相比于Java中的`Serializable`接口,它在性能上更优,但使用起来较为复杂。下面将详细解释`Parcelable`接口的工作原理、实现步骤以及其在Android开发...
2. 实现Parcelable接口:这是Android特有的序列化方式,相比于Serializable,Parcelable在性能上更优,尤其是在大量数据传递和频繁序列化操作时。但实现Parcelable接口需要编写更多的代码,对开发者的要求也更高。 ...
Android提供了两种主要的对象序列化方式:Parcelable和Serializable。下面我们将详细探讨这两种方法以及它们的使用场景和注意事项。 首先,我们来看Parcelable接口。Parcelable是Android系统提供的一个高效的对象...