1.概述

JSON 的运用非常广泛,比如我们经常将变成语言中的结构体序列化成 JSON 字符串,存入缓存或者通过网络发送给远端服务,消费者接受 JSON 字符串然后进行反序列化,就可以得到原始数据了。这就是「序列化」和「反序列化」的目的,以某种固定格式组织字符串,使得数据可以独立于编程语言。

Java提供了一种对象序列化的机制。用一个字节序列可以表示一个对象,该字节序列包含该对象的数据,对象的类型,对象中存储的属性等信息。字节序列写出到文件之后,相当于文件中持久保存了一个对象的信息。

反之,该字节序列还可以从文件中读取回来,重构对象,对它进行反序列化。对象的数据,对象的类型和对象中存储的数据信息,都可以用来在内存中创建对象。

java 反序列化嵌套json 忽略 java json序列化和反序列化_java 结构体 序列化

java 反序列化嵌套json 忽略 java json序列化和反序列化_反序列化_02

2.ObjectOutputStream(序列化)

java.io.ObjectOutputStream extends OutputStream

ObjectOutputStream 对象的序列化流

作用:把对象以流的方式写入到文件中保存

构造方法:

ObjectOutputStream(OutputStream out)  创建写入指定 OutputStream 的 ObjectOutputStream

参数:

OutputStream out: 字节输出流

特有的成员方法:

void writeObject(Object obj)    将指定的对象写入  ObjectOutputStream

使用步骤:

创建ObjectOutputStream对象,构造方法中传递字节输出流

使用ObjectOutputStream对象中的方法writeObject,把对象写入到文件中

释放资源

java 反序列化嵌套json 忽略 java json序列化和反序列化_构造方法_03

Person.java
package com.company.service.demo24;
public class Person {
private String name;
private int age;
public Person() {
}
public Person(String name, int age) {
this.name = name;
this.age = age;
}
@Override
public String toString() {
return "Person{" + "name='" + name + '\'' + ", age=" + age + '}';
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}

运行结果:

java 反序列化嵌套json 忽略 java json序列化和反序列化_反序列化_04

原因:

java 反序列化嵌套json 忽略 java json序列化和反序列化_构造方法_05

我们序列化的是Person,但是这个Person类并没有实现序列化接口

因此,我们序列化和反序列化的时候,会抛出NotSerializableException没有序列化异常

类通过实现java.io.Serializable接口以启用其序列化功能,未实现此接口的类将无法使其任何状态序列化或反序列化。

Serializable接口也叫标记型接口

要进行序列化和反序列化的类,必须实现Serializable接口,就会给类添加一个标记

当我们进行序列化和反序列化的时候,就会检测类上是否有这个标记

有:就可以序列化和反序列化

没有:就会抛出NotSerializableException异常

去市场买肉---》肉上有一个蓝色章(检测合格)---》放心购买 ----》买回来怎么吃都可以

java 反序列化嵌套json 忽略 java json序列化和反序列化_java 结构体 序列化_06

可以看到其实Serializable接口里面并没有什么东西

java 反序列化嵌套json 忽略 java json序列化和反序列化_反序列化_07

3.ObjectOutputStream(反序列化)

java.io.ObjectInputStream extends InputStream

ObjectInputStream:对象的反序列化流

作用:把文件中保存的对象,以流的方式读取出来使用

构造方法:

ObjectInputStream(InputStream in) 创建从指定 InputStream 读取的 ObjectInputStream

参数:

InputStream in :字节输入流

特有的构造方法:

Object readObject() 从ObjectInputStream读取对象。

使用步骤:

1.创建ObjectInputStream对象,构造方法中传递字节输入流

2.使用ObjectInputStream对象中的方法readObject读取保存对象的文件

3.释放资源

4.使用读取出来的对象

readObject方法声明出了ClassNotFoundException(class文件找不到异常)

当不存在对象的class文件时抛出异常

反序列化的前提:

类必须实现Serializable

必须存在类对应的class文件

java 反序列化嵌套json 忽略 java json序列化和反序列化_构造方法_08

运行结果:

java 反序列化嵌套json 忽略 java json序列化和反序列化_构造方法_09