实现java.io.Serializable
接口的类是可序列化的。没有实现此接口的类将不能使它们的任一状态被序列化或逆序列化。
例子:Integer实现了Serializable,所以可以把一个Integer的对象用IO写到文件里,之后再可以从文件里读出,如你开始写入的时候那个对象的intValue() 是5的话,那读出来之后也是5。这一点体现了用序化类的作用,即用来传送类的对象。 所谓的Serializable,就是java提供的通用数据保存和读取的接口。任何类型只要实现了Serializable接口,就可以被保存到文件中,或者作为数据流通过网络发送到别的地方。也可以用管道来传输到系统的其他程序中。这样子极大的简化了类的设计。只要设计一个保存一个读取功能就能解决上面说的所有问题。
Object serialization的定义: Object serialization 允许你将实现了Serializable接口的对象转换为字节序列,这些字节序列可以被完全存储以备以后重新生成原来的对象。
Object serialization主要用来支持一下两种主要的特性:
- Java的RMI(remote method invocation)。RMI允许像在本机上一样操作远程机器上的对象。当发送消息给远程对象时,就需要用到serializaiton机制来发送参数和接收返回值。
- Java的JavaBeans. Bean的状态信息通常是在设计时配置的。Bean的状态信息必须被存起来,以便当程序运行时能恢复这些状态信息。这也需要serializaiton机制。
其他:
- 序列化类的所有子类都是可序列化的;
- serialization不但可以在本机做,而且可以经由网络操作(RMI)。好处:自动屏蔽了操作系统的差异,字节顺序等。
public class KeepAlive implements Serializable {
private int nowTaskNum;
private int maxTaskNum;
public KeepAlive(int nowTaskNum, int maxTaskNum){
this.nowTaskNum = nowTaskNum;
this.maxTaskNum = maxTaskNum;
}
...
}
网友评论