Java 序列化与反序列化

简介: Java 序列化与反序列化

一、说明


序列化与反序列化是什么


  • 序列化:将Java对象表示为一个字节序列,存储对象数据到文件中,可用于网络传输


  • 反序列化:从文件中读取序列化对象,对它进行反序列化,恢复成Java对象


二、理解


序列化过程


  • 整个过程是JVM独立的,序列化的对象可以在不同的平台上反序列化该对象


  • 对象序列化,类必须实现Serializable接口


  • 该类的所有属性必须是可序列化的,如果有一个属性不是可序列化的,则该属性必须注明是短暂的


  • 使用IO流中的对象流实现序列化操作,将对象保存到文件,再读取出来


  • 当序列化一个对象到文件时, 按照 Java 的标准约定是给文件一个 .ser 扩展名


序列化作用


  • 对象转化为二进制,可用于网络传输


  • 把内存中的对象保存到一个文件中或者数据库中


三、实现


1.实现接口


创建一个Student类,实现Serializable接口


public  class Student implements java.io.Serializable {
    public String name;
    public String classes;
    public transient int SSN;
    public int number;
    public void checkInfo() {
        System.out.println("Student Info " + name
                + " " + classes);
    }
}


2.序列化方法


ObjectOutputStream.writeObject()方法


      FileOutputStream fileOut = new FileOutputStream("file\\student.ser");
            ObjectOutputStream out = new ObjectOutputStream(fileOut);
            out.writeObject(s);
            out.close();
            fileOut.close();


public class SerializeDemo {
    public static void main(String [] args){
        Student s = new Student();
        s.number = 17;
        s.name = "Good";
        s.classes = "computer_1";
        s.SSN = 233;
        try {
            FileOutputStream fileOut =
                    new FileOutputStream("file\\student.ser");
            ObjectOutputStream out = new ObjectOutputStream(fileOut);
            out.writeObject(s);
            out.close();
            fileOut.close();
            System.out.printf("Serialized data is saved in file/student.ser");
        }catch(IOException i) {
            i.printStackTrace();
        }
    }
}



3.反序列化方法


ObjectInputStream.readObject()方法


            FileInputStream fileIn = new FileInputStream("file\\student.ser");
            ObjectInputStream in = new ObjectInputStream(fileIn);
            s= (Student) in.readObject();
            in.close();
            fileIn.close();


public class DeserializeDemo {
    public static void main(String [] args) {
        Student s = null;
        try {
            FileInputStream fileIn = new FileInputStream("file\\student.ser");
            ObjectInputStream in = new ObjectInputStream(fileIn);
            s= (Student) in.readObject();
            in.close();
            fileIn.close();
        }catch(IOException i) {
            i.printStackTrace();
            return;
        }catch(ClassNotFoundException c) {
            System.out.println("Student class not found");
            c.printStackTrace();
            return;
        }
        System.out.println("Deserialized Student");
        System.out.println("Name: " + s.name);
        System.out.println("Address: " + s.classes);
        //SSN属性是短暂的,该值没有被发送到输出流,反序列化后属性为 0
        System.out.println("SSN: " + s.SSN);
        System.out.println("Number: " + s.number);
    }
}



目录
相关文章
|
1月前
|
JSON 网络协议 安全
【Java】(10)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
121 1
|
1月前
|
JSON 网络协议 安全
【Java基础】(1)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
137 1
|
5月前
|
JSON 安全 Java
说一说 Java 反序列化漏洞
我是小假 期待与你的下一次相遇 ~
137 1
说一说 Java 反序列化漏洞
|
4月前
|
存储 安全 Java
深入理解Java序列化接口及其实现机制
记住,序列化不仅仅是把对象状态保存下来那么简单,它涉及到类的版本控制、安全性和性能等多个重要方面。正确理解和实现Java序列化机制对于构建高效、安全和可维护的Java应用至关重要。
174 0
|
5月前
|
存储 Java 编译器
说一说关于序列化/反序列化中的细节问题
我是小假 期待与你的下一次相遇 ~
|
5月前
|
JSON Java 数据库连接
|
6月前
|
存储 安全 IDE
说一说序列化与反序列化中存在的问题
本文详细解析了Java中的序列化机制,包括序列化的概念、实现方式及应用场景。通过Student类的实例演示了对象的序列化与反序列化过程,并分析了`Serializable`接口的作用以及`serialVersionUID`的重要意义。此外,文章还探讨了如何通过自定义`readObject()`方法增强序列化的安全性,以及解决可序列化单例模式中可能产生的多实例问题。最后提供了代码示例和运行结果,帮助读者深入理解序列化的原理与实践技巧。
162 3
|
6月前
|
JSON JavaScript 前端开发
Go语言JSON 序列化与反序列化 -《Go语言实战指南》
本文介绍了 Go 语言中使用 `encoding/json` 包实现 JSON 与数据结构之间的转换。内容涵盖序列化(`Marshal`)和反序列化(`Unmarshal`),包括基本示例、结构体字段标签的使用、控制字段行为的标签(如 `omitempty` 和 `-`)、处理 `map` 和切片、嵌套结构体序列化、反序列化未知结构(使用 `map[string]interface{}`)以及 JSON 数组的解析。最后通过表格总结了序列化与反序列化的方法及类型要求,帮助开发者快速掌握 JSON 数据处理技巧。
|
存储 安全 Java
🌟Java零基础-反序列化:从入门到精通
【10月更文挑战第21天】本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
277 5
|
JSON 数据格式 索引
Python中序列化/反序列化JSON格式的数据
【11月更文挑战第4天】本文介绍了 Python 中使用 `json` 模块进行序列化和反序列化的操作。序列化是指将 Python 对象(如字典、列表)转换为 JSON 字符串,主要使用 `json.dumps` 方法。示例包括基本的字典和列表序列化,以及自定义类的序列化。反序列化则是将 JSON 字符串转换回 Python 对象,使用 `json.loads` 方法。文中还提供了具体的代码示例,展示了如何处理不同类型的 Python 对象。
449 1

热门文章

最新文章