序列化
将对象转换为字节流保存起来,并在以后还原这个对象,这种机制叫做对象的序列化。
将一个对象保存到永久的存储设备上称为持久化。
一个对象要想能够实现序列化,必须实现java.io.Serializable接口,该接口中没有定义任何方法,是一个标示性接口(Marker Interface),
当一个类实现了该接口,就表示这个类的对象是可以序列化的。
当一个对象被序列化时,只保存对象的非静态成员变量,不能保存任何的成员方法和静态的成员。
如果一个对象的成员变量是一个对象,那么这个对象的数据成员也会被保存。
如果一个可序列化的对象包含对某个不可序列化的对象的引用,那么整个序列化操作将会失败,并且会抛出一个NotSerializableException。我们可以将这个引用标记为transient,那么对象仍然可以序列化。
Serializablbe接口
-只有一个实现Serializable接口的对象可以被序列化工具存储和恢复。Serializable接口没有定义任何成员。它只用来表示一个类可以被序列化。如果一个类可以序列化,它的所有子类都可以序列化。
-声明成transient的变量不被序列化工具存储。同样,被static修饰的变量也不能被存储。
ObjectOutput接口
-ObjectOutput继承DataOutput接口,并且支持对象的序列化。特别注意writeObject()方法,它被称为序列化一个对象。所有这些方法在出错情况下引发IOException异常。
ObjectOutputStream类
-ObjectOutputStream类继承OutputStream类和实现ObjectOutput接口。它负责向流写入对象。该类的构造方法如下:
ObjectOutputStream(OutputStream outStream) throws IOException,参数outStream是序列化的对象将要写入的输出流
ObjectInput接口
-ObjectInput接口继承DataInput接口。它支持对象序列化,特别注意readObject()方法,它叫反序列化对象。所有这些方法在出错情况下引发IOException异常。
ObjectInputStream类
ObjectInputStream继承InputStream类并实现ObjectInput接口。ObjectInputStream负责从流中读取对象。该类的构造方法如下:
ObjectInputStream(InputStream inStream) throws IOException, StreamCorruptedException,参数inStream是序列化对象将被读取的输入流
分享到:
相关推荐
Java序列化是Java平台中的一种标准机制,允许将对象的状态转换为字节流,以便存储在磁盘上、通过网络进行传输或者在某些时候恢复原来的对象状态。这一过程包括两个主要步骤:对象的序列化(将对象转换为字节流)和反...
Java序列化是Java平台中的一种持久化机制,它允许对象的状态被转换成字节流,以便存储、网络传输或在不同时间点恢复。这个过程被称为序列化,而反向操作称为反序列化。序列化在许多场景下都非常有用,比如在分布式...
java 序列化和反序列化的方法 Java 序列化和反序列化是 Java 语言中的一种机制,用于将对象转换为字节流,以便在网络上传输或存储。序列化是将对象转换为字节流的过程,而反序列化是将字节流转换回对象的过程。 在...
### Java序列化(Serializable)的作用与反序列化详解 #### 一、序列化的概念 序列化是指将程序中的对象转换为一系列字节流的过程,主要用于保存对象的状态或在网络之间传输对象。序列化的主要目的是为了能够持久化...
【Protocol Buffer序列化对比Java序列化】 Protocol Buffer(简称PB)是Google开发的一种高效的数据序列化协议,而Java序列化是Java平台内置的一种序列化机制。两者的主要目标都是将对象转化为字节数组,便于在网络...
Java序列化是Java平台提供的一种持久化机制,它允许我们将一个Java对象转换为字节流,以便存储到磁盘上,或者通过网络进行传输。这使得我们可以保存和恢复对象的状态。实现序列化的类需要实现`Serializable`接口,...