Java序列化API的使用

本文涉及的产品
系统运维管理,不限时长
简介: Java序列化API的使用

Java对象序列化

为什么需要序列化呢?详情可以看一下这篇博客

https://blog.csdn.net/liu16659/article/details/85793686

Java序列化API为处理对象序列化提供了一个标准机制,具体的Java序列化需要注意以下事项

  • 类要实现序列化功能,只需要 实现java.io.Serializable接口即可
  • 序列化和反序列化必须保持序列化的ID一致,一般使用
private static final long serializableId 
  • 定义序列化的ID
  • 序列化并不保存静态变量
  • 在序列化父类变量时,父类也需要实现Serializable接口
  • 使用transient关键字可以防止该变量被序列化,再被反序列化之后,transient变量的值被设定为对应类型的初始值,例如,int类型的变量的值是0,对象类型的变量会是null。
package com.oracle.serializable;
import java.io.*;
/**
 * @author zhouyanxiang
 * @create 2020-08-2020/8/17-18:29
 * 序列化之后乱码是正常的,因为序列化和反序列话是基于二进制流的,序列话便是把java对象的信息以二进制存储在文件obj.bat中,用文本编辑器打开自然是乱码。
 * 只有通过反序列话才能将存储的二进制读取出来,然后显示在控制台上。
 */
public class SerializableReview {
    static class Worker implements Serializable {
        // 自定义序列化的ID
        private static final long serializableId = 123456789L;
        // 将要被序列化的属性name
        private String  name;
        // transient修饰的变量不会被序列化
        private transient int salary;
        // 静态变量属于类信息,不属于对象的状态,因此不会被序列化
        static int age = 23;
        public String getName() {
            return name;
        }
        public void setName(String name) {
            this.name = name;
        }
    }
    public static void main(String[] args) throws IOException, ClassNotFoundException {
        // 序列化到磁盘
        FileOutputStream fos =  new FileOutputStream("work.out");
        ObjectOutputStream oos = new ObjectOutputStream(fos);
        Worker  worker = new Worker();
        worker.setName("alex");
        oos.writeObject(worker);
        oos.flush();
        oos.close();
        // 反序列化磁盘数据并解析磁盘数据
        FileInputStream fis =  new FileInputStream("work.out");
        ObjectInputStream  ois = new ObjectInputStream(fis);
        Worker workerTest = (Worker) ois.readObject();
        System.out.println(workerTest.getName());
    }
}

直接打开文件将会是乱码的

只有通过反序列化才能读出对象的信息

Java序列化API为处理对象序列化提供了一个标准机制,具体的Java序列化需要注意以下事项

  • 类要实现序列化功能,只需要 实现java.io.Serializable接口即可
  • 序列化和反序列化必须保持序列化的ID一致,一般使用
private static final long serializableId 
  • 定义序列化的ID
  • 序列化并不保存静态变量
  • 在序列化父类变量时,父类也需要实现Serializable接口
  • 使用transient关键字可以防止该变量被序列化,再被反序列化之后,transient变量的值被设定为对应类型的初始值,例如,int类型的变量的值是0,对象类型的变量会是null。
package com.oracle.serializable;
import java.io.*;
/**
 * @author zhouyanxiang
 * @create 2020-08-2020/8/17-18:29
 * 序列化之后乱码是正常的,因为序列化和反序列话是基于二进制流的,序列话便是把java对象的信息以二进制存储在文件obj.bat中,用文本编辑器打开自然是乱码。
 * 只有通过反序列话才能将存储的二进制读取出来,然后显示在控制台上。
 */
public class SerializableReview {
    static class Worker implements Serializable {
        // 自定义序列化的ID
        private static final long serializableId = 123456789L;
        // 将要被序列化的属性name
        private String  name;
        // transient修饰的变量不会被序列化
        private transient int salary;
        // 静态变量属于类信息,不属于对象的状态,因此不会被序列化
        static int age = 23;
        public String getName() {
            return name;
        }
        public void setName(String name) {
            this.name = name;
        }
    }
    public static void main(String[] args) throws IOException, ClassNotFoundException {
        // 序列化到磁盘
        FileOutputStream fos =  new FileOutputStream("work.out");
        ObjectOutputStream oos = new ObjectOutputStream(fos);
        Worker  worker = new Worker();
        worker.setName("alex");
        oos.writeObject(worker);
        oos.flush();
        oos.close();
        // 反序列化磁盘数据并解析磁盘数据
        FileInputStream fis =  new FileInputStream("work.out");
        ObjectInputStream  ois = new ObjectInputStream(fis);
        Worker workerTest = (Worker) ois.readObject();
        System.out.println(workerTest.getName());
    }
}

直接打开文件将会是乱码的

只有通过反序列化才能读出对象的信息


相关文章
|
20天前
|
Java API Spring
打造未来电商新引擎:揭秘Java可扩展API设计,让支付与物流灵活如丝,引领电商时代潮流!
【8月更文挑战第30天】本文通过电商平台案例,探讨了如何设计可扩展的Java API。首先定义支付和物流服务的接口与抽象类,然后实现具体服务,接着引入工厂模式或依赖注入管理服务实例,最后通过配置实现灵活扩展。这种设计确保了应用架构的灵活性和长期稳定性。
36 3
|
21天前
|
安全 Java API
告别繁琐编码,拥抱Java 8新特性:Stream API与Optional类助你高效编程,成就卓越开发者!
【8月更文挑战第29天】Java 8为开发者引入了多项新特性,其中Stream API和Optional类尤其值得关注。Stream API对集合操作进行了高级抽象,支持声明式的数据处理,避免了显式循环代码的编写;而Optional类则作为非空值的容器,有效减少了空指针异常的风险。通过几个实战示例,我们展示了如何利用Stream API进行过滤与转换操作,以及如何借助Optional类安全地处理可能为null的数据,从而使代码更加简洁和健壮。
55 0
|
8天前
|
Java API C++
Java 8 Stream Api 中的 peek 操作
本文介绍了Java中`Stream`的`peek`操作,该操作通过`Consumer<T>`函数消费流中的每个元素,但不改变元素类型。文章详细解释了`Consumer<T>`接口及其使用场景,并通过示例代码展示了`peek`操作的应用。此外,还对比了`peek`与`map`的区别,帮助读者更好地理解这两种操作的不同用途。作者为码农小胖哥,原文发布于稀土掘金。
Java 8 Stream Api 中的 peek 操作
|
12天前
|
安全 Java API
【性能与安全的双重飞跃】JDK 22外部函数与内存API:JNI的继任者,引领Java新潮流!
【9月更文挑战第7天】JDK 22外部函数与内存API的发布,标志着Java在性能与安全性方面实现了双重飞跃。作为JNI的继任者,这一新特性不仅简化了Java与本地代码的交互过程,还提升了程序的性能和安全性。我们有理由相信,在外部函数与内存API的引领下,Java将开启一个全新的编程时代,为开发者们带来更加高效、更加安全的编程体验。让我们共同期待Java在未来的辉煌成就!
41 11
|
13天前
|
安全 Java API
【本地与Java无缝对接】JDK 22外部函数和内存API:JNI终结者,性能与安全双提升!
【9月更文挑战第6天】JDK 22的外部函数和内存API无疑是Java编程语言发展史上的一个重要里程碑。它不仅解决了JNI的诸多局限和挑战,还为Java与本地代码的互操作提供了更加高效、安全和简洁的解决方案。随着FFM API的逐渐成熟和完善,我们有理由相信,Java将在更多领域展现出其强大的生命力和竞争力。让我们共同期待Java编程新纪元的到来!
36 11
|
10天前
|
监控 Java 大数据
【Java内存管理新突破】JDK 22:细粒度内存管理API,精准控制每一块内存!
【9月更文挑战第9天】虽然目前JDK 22的确切内容尚未公布,但我们可以根据Java语言的发展趋势和社区的需求,预测细粒度内存管理API可能成为未来Java内存管理领域的新突破。这套API将为开发者提供前所未有的内存控制能力,助力Java应用在更多领域发挥更大作用。我们期待JDK 22的发布,期待Java语言在内存管理领域的持续创新和发展。
|
12天前
|
Java API 数据处理
【Java的SIMD革命】JDK 22向量API:释放硬件潜能,让Java应用性能飙升!
【9月更文挑战第7天】 JDK 22向量API的发布标志着Java编程语言在SIMD技术领域的重大突破。这一新特性不仅释放了现代硬件的潜能,更让Java应用性能实现了飙升。我们有理由相信,在未来的发展中,Java将继续引领编程语言的潮流,为开发者们带来更加高效、更加强大的编程体验。让我们共同期待Java在SIMD技术的推动下开启一个全新的性能提升时代!
|
6天前
|
存储 Java
Java编程中的对象序列化与反序列化
【9月更文挑战第12天】在Java的世界里,对象序列化与反序列化是数据持久化和网络传输的关键技术。本文将带你了解如何通过实现Serializable接口来标记一个类的对象可以被序列化,并探索ObjectOutputStream和ObjectInputStream类的使用,以实现对象的写入和读取。我们还将讨论序列化过程中可能遇到的问题及其解决方案,确保你能够高效、安全地处理对象序列化。
|
13天前
|
Java API 开发者
【Java字节码操控新篇章】JDK 22类文件API预览:解锁Java底层的无限可能!
【9月更文挑战第6天】JDK 22的类文件API为Java开发者们打开了一扇通往Java底层世界的大门。通过这个API,我们可以更加深入地理解Java程序的工作原理,实现更加灵活和强大的功能。虽然目前它还处于预览版阶段,但我们已经可以预见其在未来Java开发中的重要地位。让我们共同期待Java字节码操控新篇章的到来!
|
11天前
|
Java API 开发者
【Java字节码的掌控者】JDK 22类文件API:解锁Java深层次的奥秘,赋能开发者无限可能!
【9月更文挑战第8天】JDK 22类文件API的引入,为Java开发者们打开了一扇通往Java字节码操控新世界的大门。通过这个API,我们可以更加深入地理解Java程序的底层行为,实现更加高效、可靠和创新的Java应用。虽然目前它还处于预览版阶段,但我们已经可以预见其在未来Java开发中的重要地位。让我们共同期待Java字节码操控新篇章的到来,并积极探索类文件API带来的无限可能!