Java中对象序列化过程(序列化本身在.net和Java系列当中都有不同的实现,根据序列化格式的不同包含xml和二进制的序列化格式,在java.io.serializable进行二进制序列化):
Java序列化:
public class Test implements Serializable{
/**
* @add by: 在原有代码基础上新增属性时需填写
*/
private static final long serialVersionUID = -3772479206916799373L;
public static void main(String[] args) throws IOException{
SerialTest st = new Test().new SerialTest();
st.setName("name");
st.setUID(1);
File cf = new File("D:/dev/a.out");
cf.createNewFile();
FileOutputStream fis = new FileOutputStream(cf);
ObjectOutputStream oop = new ObjectOutputStream(fis);
oop.writeObject(st);
oop.flush();
oop.close();
}
private class SerialTest implements Serializable{
/**
* @add by: 在原有代码基础上新增属性时需填写
*/
private static final long serialVersionUID = 7057425092293945310L;
private String name;
private Integer UID;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Integer getUID() {
return UID;
}
public void setUID(Integer UID) {
this.UID = UID;
}
public String toString(){
return this.getName()+this.getUID();
}
}
}
Java反序列化:
public class Test implements Serializable{
/**
* @add by: 在原有代码基础上新增属性时需填写
*/
private static final long serialVersionUID = -3772479206916799373L;
public static void main(String[] args) throws IOException, ClassNotFoundException{
File cf = new File("D:/dev/a.out");
FileInputStream fis = new FileInputStream(cf);
ObjectInputStream oop = new ObjectInputStream(fis);
SerialTest st = (SerialTest)oop.readObject();
System.out.println(st.toString());
}
private class SerialTest implements Serializable{
/**
* @add by: 在原有代码基础上新增属性时需填写
*/
private static final long serialVersionUID = 7057425092293945310L;
private String name;
private Integer UID;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Integer getUID() {
return UID;
}
public void setUID(Integer UID) {
this.UID = UID;
}
public String toString(){
return this.getName()+this.getUID();
}
}
}
序列化要点:
- 作用--对象持久化,便于保存和传输。
- 如果该类有父类,当其父类实现Serializable接口时,可以将父类属性序列化;如果没有实现Serializable接口,父类属性不被序列化;
- 如果该属性被标示为static,则该属性不能被序列化;
- transient关键字--表明当前属性不应被序列化,由于序列化将对象转换成字节流保存下来,比较耗费IO性能,涉及到以下情况时: 1、如果一些属性涉及到线程共享;2、需要访问IO、本地资源、网络资源等的属性;3、该属性为一个关联类,当该类没有实现Serializable接口并且未被标示为transient时,会报java.io.NotSerializableException异常;4、当A类为B类的非静态内部类时,对A序列化时,需要B也实现Serializable接口,否则会报java.io.NotSerializableException异常;
- 序列化针对的内容是该对象的属性(即对象状态的载体),对象方法不会被序列化,方法信息可以通过对象加载后在保存Class信息的方法区取到;
- 反序列化时的ClassLoader和序列化时的ClassLoader一致。
- 序列化针对的是:对象的类,类签名,以及非瞬态和非静态字段的值。
- 序列化操作不写出没有实现 java.io.Serializable 接口的任何对象的字段。不可序列化的 Object 的子类可以是可序列化的。在此情况下,不可序列化的类必须有一个无参数构造方法,以便允许初始化其字段。在此情况下,子类负责保存和还原不可序列化的类的状态。经常出现的情况是,该类的字段是可访问的(public、package 或 protected),或者存在可用来还原状态的 get 和 set 方法。
- 实现 Externalizable 接口允许对象假定可以完全控制对象的序列化形式的内容和格式。调用 Externalizable 接口的方法(writeExternal 和 readExternal)来保存和恢复对象的状态。通过类实现时,它们可以使用 ObjectOutput 和 ObjectInput 的所有方法读写它们自己的状态。对象负责处理出现的任何版本控制。
- 基本数据(不包括 serializable 字段和 externalizable 数据)以块数据记录的形式写入 ObjectOutputStream 中。块数据记录由头部和数据组成。块数据部分包括标记和跟在部分后面的字节数。连续的基本写入数据被合并在一个块数据记录中。块数据记录的分块因子为 1024 字节。每个块数据记录都将填满 1024 字节,或者在终止块数据模式时被写入。调用 ObjectOutputStream 方法 writeObject、defaultWriteObject 和 writeFields 最初只是终止所有现有块数据记录。
在序列化时,首先是将一个类的对象信息读取出来放入,按照一种约定格式转换成字节流的形式(以二进制的形式进行存储),持久化存入本地硬盘。
反序列化时,首先将对应的Class信息通过ClassLoader读取出来,在读取当前二进制流文件转换成当前对象对应的属性值。
序列化过程步骤:首先输出当前类的
元数据(在序列化一个对象时,通过序列化后得到的文件大小即可知道其中包含该对象的元数据信息,序列化后文件大小=对象状态数据+元数据+序列化格式信息),之后递归输出当前类的父类的元数据直到没有父类,从顶层父类开始数据属性对应的数据值,从上往下递归输出数据值。
分享到:
相关推荐
Java序列化机制是Java平台提供的一种标准方法,用于将对象的状态转换为字节序列,以便在网络中传输或存储在磁盘、数据库等持久化介质中。这一机制在分布式环境、远程通信、持久化存储和数据交换等多个场景下具有广泛...
Java序列化机制就是为了满足这种需求而产生的。通过序列化,我们可以将对象转换为字节流,从而使得对象可以通过网络传输或者持久化存储。 #### 三、实现序列化的步骤 1. **实现Serializable接口**:为了使一个对象...
首先,我们需要创建一个实现了`Serializable`接口的类`TestSerial`,这样Java序列化机制才能处理这个类的对象。 接下来,我们编写代码将对象序列化并输出为字节流,存储在一个临时文件`temp.out`中。 ```java ...
在给定的链接"Java序列化机制(2)- serialVersionUID 实验"中,博主通过一个实验详细解释了`serialVersionUID`的作用和重要性。实验可能包括以下步骤: 1. 创建一个实现`Serializable`接口的简单类,并运行序列化...
Java 序列化机制 Java 序列化机制是一种将对象状态写入 Byte 流里的技术,并可以从其它地方把该 Byte 流里的数据读出来,重新构造一个相同的对象。这种机制允许将对象通过网络进行传播,并可以随时把对象持久化到...
序列化ID,即`serialVersionUID`,是Java序列化机制中一个关键的概念。它是一个类的唯一标识符,用于在序列化和反序列化过程中确定类的版本一致性。如果序列化对象和反序列化对象的`serialVersionUID`不匹配,将会抛...
通过实例深入了解 Java 序列化,可以帮助开发人员更好地理解 Java 序列化机制,避免一些常见的问题,提高开发效率。本文通过分析一些真实情境,帮助读者轻松牢记 Java 序列化中的一些高级认识。
Java 序列化和反序列化是 Java 语言中的一种机制,用于将对象转换为字节流,以便在网络上传输或存储。序列化是将对象转换为字节流的过程,而反序列化是将字节流转换回对象的过程。 在 Java 中,序列化和反序列化是...
Java序列化是Java平台中的一种持久化机制,它允许对象的状态被转换成字节流,以便存储、网络传输或在不同时间点恢复...理解和熟练掌握序列化机制,以及知道如何避免其潜在问题,对于任何Java开发者来说都是至关重要的。
1. **Java序列化机制**:Java对象序列化是通过实现`Serializable`接口来标记一个类可被序列化。`ObjectOutputStream`用于将对象写入流,`ObjectInputStream`用于从流中读取并反序列化对象。 2. **易受攻击的库**:...
Java 序列化机制是通过实现 java.io.Serializable 接口来实现的。该接口没有任何方法,但它标志着该类的对象可以被序列化。如果一个类实现了 Serializable 接口,那么该类的所有属性必须是可序列化的。如果有一个...
通过实例了解java序列化机制 知识点1: 序列化机制的定义 Java 序列化机制是指对象通过写出描述自己状态的数值来记录自己的过程,即将对象表示成一系列有序字节。序列化机制主要用于对象的存储和传输。 知识点2: ...
Protocol Buffer(简称PB)是Google开发的一种高效的数据序列化协议,而Java序列化是Java平台内置的一种序列化机制。两者的主要目标都是将对象转化为字节数组,便于在网络传输、持久化存储等场景中使用。然而,它们...
- Java序列化是Java平台提供的一种持久化机制,它允许将对象转换为字节序列,这样就可以保存在文件中或在网络上传输。 - 序列化不仅可以用来持久化数据,还可以用于进程间通信(IPC)和远程方法调用(RMI)。 2. ...
Java序列化机制的优点在于它提供了一种标准的方式来处理对象的持久化和在网络间的传输。然而,序列化也存在安全风险,比如序列化可能导致远程代码执行攻击。因此,对于敏感信息或复杂对象结构,应谨慎使用序列化,并...
以下是关于Java序列化机制和原理的详细解释: 1. **序列化接口**: Java中的序列化是通过实现`Serializable`接口来实现的。这个接口没有任何方法,它的存在仅仅是为了标记一个类可以被序列化。如以下示例所示: `...
Java 序列化机制 Java 序列化是将一个对象的状态写入一个 Byte 流里,并且可以从其它地方把该 Byte 流里的数据读出来,重新构造一个相同的对象。这种机制允许你将对象通过网络进行传播,并可以随时把对象持久化到...
Java序列化是Java平台提供的一种持久化机制,它允许我们将一个Java对象转换为字节流,以便存储到磁盘上,或者通过网络进行传输。这使得我们可以保存和恢复对象的状态。实现序列化的类需要实现`Serializable`接口,...
- **重要性**:Java序列化机制依赖于`serialVersionUID`字段来验证序列化版本的一致性。 - **默认生成**:当类首次序列化时,JVM会根据类的结构自动生成一个`serialVersionUID`。 - **手动指定**:为了确保反序列...