android 进程间通信数据(一)------parcel的起源
关于parcel,我们先来讲讲它的“父辈” Serialize。
Serialize 是java提供的一套序列化机制。但是为什么要序列化,怎么序列化,序列化是怎么做到的,我们将在本文探讨下。
一:java 中的serialize
关于Serialize这个东东,think in java其实说的很详细,大意如下:
1.Serialize的目的
当你创建对象时,你需要,它一直存在,但是当程序终止时,它就消失了。
如果程序不运行的情况下,可以保存某些信息,这将非常有用。
如何我程序在下次运行的时候,可以把上次运行的某些信息恢复回来.
2.Serialize的使用:
使用一个嵌套的Serializable对象
package com.joyfulmath.androidstudy.bind.worm;
import java.io.Serializable;
public class Data implements Serializable {
private int n;
public Data(int n) {
this.n = n;
}
@Override
public String toString() {
return Integer.toString(n);
}
}
package com.joyfulmath.androidstudy.bind.worm; import java.io.Serializable;
import java.util.Random; import com.joyfulmath.androidstudy.TraceLog; public class Worm implements Serializable {
static Random rand = new Random(47);
Data[] d = {
new Data(rand.nextInt(10)),
new Data(rand.nextInt(10)),
new Data(rand.nextInt(10))
}; private Worm next;
private char c; public Worm(int i, char x)
{
TraceLog.i("Worm construct:"+i);
c = x;
if(--i>0)
{
next = new Worm(i,(char) (x+1));
}
} public Worm()
{
TraceLog.i("default Worm construct");
} @Override
public String toString() {
StringBuilder result = new StringBuilder(":");
result.append(c);
result.append("(");
for(Data dat:d)
{
result.append(dat+" ");
}
result.append(")");
if(next!=null)
{
result.append(next);
}
return result.toString();
} }
验证序列化的读写:
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream; import com.joyfulmath.androidstudy.TraceLog; public class WormSample { static final String path = "/mnt/sdcard/worm.out";
public void doAction()
{
Worm w = new Worm(6, 'a');
TraceLog.i("\n"+w.toString()); try {
ObjectOutputStream opt = new ObjectOutputStream(new FileOutputStream(path));
opt.writeObject("Worm object\n");
opt.writeObject(w);
opt.close();
ObjectInputStream in = new ObjectInputStream(new FileInputStream(path));
String s = (String) in.readObject();
Worm w2 = (Worm) in.readObject();
TraceLog.i(s+w);
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
最后log:
08-15 09:18:20.384: I/Worm(28437): <init>: Worm construct:6 [at (Worm.java:21)]
08-15 09:18:20.384: I/Worm(28437): <init>: Worm construct:5 [at (Worm.java:21)]
08-15 09:18:20.384: I/Worm(28437): <init>: Worm construct:4 [at (Worm.java:21)]
08-15 09:18:20.384: I/Worm(28437): <init>: Worm construct:3 [at (Worm.java:21)]
08-15 09:18:20.384: I/Worm(28437): <init>: Worm construct:2 [at (Worm.java:21)]
08-15 09:18:20.384: I/Worm(28437): <init>: Worm construct:1 [at (Worm.java:21)]
08-15 09:18:20.384: I/WormSample(28437): doAction:
08-15 09:18:20.384: I/WormSample(28437): :a(853):b(119):c(802):d(788):e(199):f(881) [at (WormSample.java:18)]
08-15 09:18:20.414: I/WormSample(28437): doAction: Worm object
08-15 09:18:20.414: I/WormSample(28437): :a(853):b(119):c(802):d(788):e(199):f(881) [at (WormSample.java:28)]
可以看到,数据被很好的还原了,包含内部的序列化对象!
二:parcel
Serializable是java定义的一套序列化机制,但是他是操作文件来执行的。或者说,它的性能无法满足android上的要求,
这样,parcel被google发明出来,用以取代Serializable。
1.Parcelable 的使用
package com.joyfulmath.androidstudy.bind.worm; import android.os.Parcel;
import android.os.Parcelable; public class DataP implements Parcelable { public int n; public DataP(int n) {
this.n = n;
} @Override
public int describeContents() {
return 0;
} @Override
public void writeToParcel(Parcel dest, int flags) {
dest.writeInt(n);
} public static final Parcelable.Creator<DataP> CREATOR = new Parcelable.Creator<DataP>()
{
public DataP createFromParcel(Parcel in)
{
return new DataP(in);
} public DataP[] newArray(int size)
{
return new DataP[size];
}
}; private DataP(Parcel in)
{
n = in.readInt();
} @Override
public String toString() {
return Integer.toString(n);
} }
package com.joyfulmath.androidstudy.bind.worm; import java.util.Random; import com.joyfulmath.androidstudy.TraceLog; import android.os.Parcel;
import android.os.Parcelable; public class WormP implements Parcelable { static Random rand = new Random(47);
public DataP[] d = { new DataP(rand.nextInt(10)), new DataP(rand.nextInt(10)),
new DataP(rand.nextInt(10)) }; private WormP next;
public byte c; public WormP(int i,byte x)
{
TraceLog.i("Wormp construct:"+i);
c = x;
if(--i>0)
{
next = new WormP(i,(byte) (x+1));
}
} @Override
public int describeContents() {
return 0;
} @Override
public void writeToParcel(Parcel dest, int flags) {
dest.writeByte(c);
dest.writeParcelableArray(d, 0);
if (next != null) {
dest.writeParcelable(next, 0);
}
} public static final Parcelable.Creator<WormP> CREATOR = new Parcelable.Creator<WormP>() {
public WormP createFromParcel(Parcel in) {
return new WormP(in);
} public WormP[] newArray(int size) {
return new WormP[size];
}
}; private WormP(Parcel in) {
c = in.readByte();
d = (DataP[]) in.readParcelableArray(DataP.class.getClassLoader());
} @Override
public String toString() {
StringBuilder result = new StringBuilder(":");
result.append(c);
result.append("(");
for(DataP dat:d)
{
result.append(dat+" ");
}
result.append(")");
if(next!=null)
{
result.append(next);
}
return result.toString();
}
}
parcel一般使用在intent的内容的传递,所以本处做一个简单的模拟:
public void doActionP()
{
TraceLog.i();
byte a = 'a';
WormP w = new WormP(6, a);
TraceLog.i(w.toString());
Intent intent = new Intent();
intent.putExtra("wormp", w);
///...
Intent newIntent = new Intent(intent);
WormP w2 = newIntent.getParcelableExtra("wormp");
TraceLog.i(w2.toString());
TraceLog.i("end");
}
08-15 10:14:11.924: I/WormSample(20183): doActionP: [at (WormSample.java:47)]
08-15 10:14:11.934: I/WormP(20183): <init>: Wormp construct:6 [at (WormP.java:21)]
08-15 10:14:11.934: I/WormP(20183): <init>: Wormp construct:5 [at (WormP.java:21)]
08-15 10:14:11.934: I/WormP(20183): <init>: Wormp construct:4 [at (WormP.java:21)]
08-15 10:14:11.934: I/WormP(20183): <init>: Wormp construct:3 [at (WormP.java:21)]
08-15 10:14:11.934: I/WormP(20183): <init>: Wormp construct:2 [at (WormP.java:21)]
08-15 10:14:11.934: I/WormP(20183): <init>: Wormp construct:1 [at (WormP.java:21)]
08-15 10:14:11.934: I/WormSample(20183): doActionP: :97(8 5 3 ):98(1 1 9 ):99(8 0 2 ):100(7 8 8 ):101(1 9 9 ):102(8 8 1 ) [at (WormSample.java:50)]
08-15 10:14:11.934: I/WormSample(20183): doActionP: :97(8 5 3 ):98(1 1 9 ):99(8 0 2 ):100(7 8 8 ):101(1 9 9 ):102(8 8 1 ) [at (WormSample.java:59)]
08-15 10:14:11.934: I/WormSample(20183): doActionP: end [at (WormSample.java:61)]
可以看到结果,数据完全正确。
以上就是parcel的使用方式,在下一篇,将探索parcel的实现方式。
参考:
http://blog.csdn.net/niu_gao/article/details/6451699
android 进程间通信数据(一)------parcel的起源的更多相关文章
- android 进程间通信数据(二)------parcel的实现
Serialize是java原生就自带的东西,我们可以看到android的源码 所以看看android是如何实现parcel的,这对我们自己代码设计有什么启发. Parcel: 在android中,p ...
- Android 进程间通信
什么鬼!单例居然失效了,一个地方设置值,另个地方居然取不到,这怎么可能?没道理啊!排查半天,发现这两就不在一个进程里,才恍然大悟-- 什么是进程 按照操作系统中的描述:进程一般指一个执行单元,在 PC ...
- Android进程间通信-AIDL实现原理
Android进程间通信基于Proxy(代理)与Stub(桩或存根)的设计模式(如图1-1所示).其中,Proxy将特殊性接口转换成通用性接口,Stub将通用性接口转换成特殊性接口,二者之间的数据转换 ...
- 浅谈Service Manager成为Android进程间通信(IPC)机制Binder守护进程之路
文章转载至CSDN社区罗升阳的安卓之旅,原文地址:http://blog.csdn.net/luoshengyang/article/details/6621566 上一篇文章Android进程间通信 ...
- [转]Android进程间通信
Android进程间通信 一.Linux系统进程间通信有哪些方式? 1.socket: 2.name pipe命名管道: 3.message queue消息队列: 4.singal信号量: 5.sha ...
- Android 进程间通信——AIDL
代码地址如下:http://www.demodashi.com/demo/12321.html 原文地址:http://blog.csdn.net/vnanyesheshou/article/deta ...
- Android中数据存储(一)
国庆没有给国家添堵,没有勾搭妹子,乖乖的写着自己的博客..... 本文将为大家介绍Android中数据存储的五种方式,数据存储可是非常重要的知识哦. 一,文件存储数据 ①在ROM存储数据 关于在ROM ...
- Android本地数据存储复习
Android本地数据存储复习 Android无论是应用层还是系统层都需要在本地保存一些数据,尤其在应用层中使用的就更为普遍,大体有这么几种:SharedPreference,file,sqlite数 ...
- Android提交数据到JavaWeb服务器实现登录
之前学习Android提交数据到php服务器没有成功,在看了两三个星期的视频之后,现在终于实现了与服务器的交互.虽然完成的不是PHP端的,但是在这个过程还是学到了不少东西的.现在我先来展示一下我的成果 ...
随机推荐
- 富客户端 wpf, Winform 多线程更新UI控件
前言 在富客户端的app中,如果在主线程中运行一些长时间的任务,那么应用程序的UI就不能正常相应.因为主线程要负责消息循环,相应鼠标等事件还有展现UI. 因此我们可以开启一个线程来格外处理需要长时间的 ...
- Quartz中的时间表达式介绍和常用表达式
Quartz.NET是一个开源的作业调度框架,是 OpenSymphony 的 Quartz API 的.NET移植,它用C#写成,可用于winform和asp.net应用中.它提供了巨大的灵活性而不 ...
- 初学C++ 之 输入输出(IDE:vs2013)
#include <iostream> //引用头文件(输入输出) using namespace std; //引用命名空间,方便使用输入输出语句 class MathMethod { ...
- Android总结篇系列:Android广播机制
1.Android广播机制概述 Android广播分为两个方面:广播发送者和广播接收者,通常情况下,BroadcastReceiver指的就是广播接收者(广播接收器).广播作为Android组件间的通 ...
- GJM:用C#实现网络爬虫(一) [转载]
网络爬虫在信息检索与处理中有很大的作用,是收集网络信息的重要工具. 接下来就介绍一下爬虫的简单实现. 爬虫的工作流程如下 爬虫自指定的URL地址开始下载网络资源,直到该地址和所有子地址的指定资源都下载 ...
- 设计一个较好的框架的难点之一--API兼容性的设计
设计一个好的框架和设计一个好的软件一样,需要考虑的方面很多,比如扩展性.性能.用户体验.稳健性等等,视不同的场景,每个点都可能导致成败,但他们通常并不是老板们关心的,因为在大部分情况下,他们通常都没有 ...
- jstl标签2
我们前面讲的是ArrayList集合迭代,Hashmap/Hashset的情况下 举例: <h3>对map和set的迭代</h3> 放入字符串 <% //模拟 Map m ...
- Linux更改主机名-适用于abuntu
今天复制了个ubuntu虚拟机,于是想更改下主机名以作区别.这是搜到的比较完整的资料,适用abuntu,不过其他linux系统还有待求证. 1.查看主机名 在Ubuntu系统中,快速查看主机名有多种方 ...
- UrlRewrite(URL重写)--ASP.NET中的实现
概述 今天看了下URL重写的实现,主要看的是MS 的URL Rewrite. URL重写的优点有:更友好的URL,支持老版本的URL URL重写的缺点有:最主要的缺点是性能低下,因为如果要支持无后缀的 ...
- 20款时尚的 WordPress 博客主题【免费下载】
在这篇文章中,我们收集了20款时尚的 WordPress 博客模板.WordPress 作为最流行的博客系统,插件众多,易于扩充功能.安装和使用都非常方便,而且有许多第三方开发的免费模板,安装方式简单 ...