1.1
IPC基础概念介绍
IPC主要包含三方面内容:Serializable接口,Parcelable接口和Binder,只有熟悉这三方面的内容后,我们才能更好地理解跨进程通信的各种方式。Serializable和Parcelable接口中可以完成对象序列化过程,当我们需要Intent和Binder传输数据时就需要使用Parcelable或者Serializable。有时候需要把对象持久化到存储设备上或者通过网络传输给其它客户端,这个时候需要Serializable来完成对象的持久化。
-
Serializable接口
Serializable是java所提供的序列化接口,它是空接口,为对象提供标准的序列化和反序列化操作。使用Serializable来实现序列化非常简单,只需在类的声明中指定的一个类似下面的一个标识即可自动实现默认的序列化过程
private static final long SerialVersionUID=83784829378278367874882243L
实际上,这个SerialVersionUID也不是必须的,不声明这个SerialVesionUID也能实现序列化,不过对反序列化过程产生影响,
public class User implements Serializable{
private static final long SerialVersionUID=519067123721295772L;
public String userName;
public boolean isMale;
...
}
通过Serializable方式来实现对象的序列化,实现起来非常简单,几乎所有工作都被系统自动完成了。如何进行对象的序列化和反序列化也非常简单,只需采用ObjectOutputStream和ObjectInputStream即可轻松实现。
//序列化过程
User user=new User(0,"zjl",ture);
ObjectOutputStream out=new ObjectOutputStream(
new FileOutputStream("cache.txt"));
out.writeObject(user);
out.close;
//反序列化过程
ObjectInputStream in=new ObjectInputStream(new FileInputStream("cache.txt"));
User newuser=(User)in.readObject();
in.close;
上述代码演示了采用Serializable方式序列化对象的典型过程,很简单,只需要把实现Serializable接口的User对象写到文件中就可以快速恢复啦。恢复后 的对象newuser和user的内容完全一样,但两者并不是同一个对象。
至于SerialVsionUID在反序列化起的作用,大家百度吧笔者不作多介绍。
2.Parcelable接口