Java在线运行

版本:

所属目录
点击了解高性能代码运行API
运行结果
教程手册
代码仓库
极速运行
交互输入
极速运行模式,更高效的运行,点击编辑器上方的运行按钮即刻体验吧。
以下是用户最新保存的代码
JAVB Base64URL编码/解码示例 发布于:2023-03-23 18:11 今天吃什么呢? 发布于:2023-03-22 17:37 //快速排序的代码演示 发布于:2023-03-18 21:24 按字典排序的组合 发布于:2023-03-17 10:06 01背包暴力法,基本不可能AC,填空使用 发布于:2023-03-17 00:32 迷宫问题AC 发布于:2023-03-17 00:08 JAVA 组合+ 发布于:2023-03-16 14:51 c测试程序保存 发布于:2023-03-16 11:15 JAVA 组合模板 发布于:2023-03-16 10:42 JAVA 小组分类 发布于:2023-03-16 10:34 JAVA 搭积木 发布于:2023-03-16 09:58 JAVA 牌型组合 组合+递归 发布于:2023-03-15 18:51 java first 发布于:2023-03-15 16:36 平行四边形 发布于:2023-03-16 18:29 学习枚举类 发布于:2023-03-14 15:16 vv平台留存 getBetweenDayList 发布于:2023-03-14 11:09 热点已经退回 发布于:2023-03-13 10:09 dfs模板 发布于:2023-03-13 10:24 TreeMap与HashMap 发布于:2023-03-10 14:51 学习TreeSet 发布于:2023-03-09 15:33 对象序列化与反序列化 发布于:2023-03-09 11:01 除法运算 除余运算 发布于:2023-03-08 19:22 生成验证码程序 发布于:2023-03-07 20:42 机票代码测试 发布于:2023-03-07 20:08 JAVA C10,4 发布于:2023-03-06 23:01 JAVA BFS模版(岛屿数量) 发布于:2023-03-06 22:49 JAVA 全排列+特殊预处理 蓝桥杯(李白斗酒) 发布于:2023-03-06 22:19 学习io文件操作 发布于:2023-03-06 18:52 dfs模版 发布于:2023-03-05 23:41 Hashmap的简单使用 发布于:2023-03-05 20:15 希尔排序的演示 发布于:2023-03-06 16:37 Java Hashmap 发布于:2023-03-06 19:59 JAVA 字符串分割 发布于:2023-03-03 21:19 学习链表的底层 发布于:2023-03-03 15:59 插入排序的代码 发布于:2023-03-05 10:47 java 标准版 KMP 发布于:2023-03-03 10:42 JAVA vectoe 数据结构 发布于:2023-03-02 22:47 Java 枚举类型 发布于:2023-03-02 22:32 堆的各种基础API 发布于:2023-03-02 22:19 学习arrayList的底层 发布于:2023-03-02 16:44 获取证书至服务器 发布于:2023-03-02 14:26 学习循环语句优化 发布于:2023-03-02 10:33 JAVA全排列 发布于:2023-03-07 17:33 今有 100 根绳子,当然会有 200 个绳头。 // 如果任意取绳头两两配对,把所有绳头都打结连接起来。最后会形成若干个绳圈(不考虑是否套在一起)。 // 我们的问题是:请计算最后将形成多少个绳圈的概率最大? 发布于:2023-03-01 21:46 给别人展示的测试 发布于:2023-03-01 08:56 Integer 型 发布于:2023-02-28 22:19 猜灯谜,String末尾用length()-1来表示 发布于:2023-02-28 19:49 倒挂的招牌 发布于:2023-02-27 21:32 铣削切削参数优化 发布于:2023-02-27 21:57 选择排序的代码 发布于:2023-02-28 10:28 [更多]
显示目录

序列化



Java 序列化

Java 提供了一种对象序列化的机制,该机制中,一个对象可以被表示为一个字节序列,该字节序列包括该对象的数据、有关对象的类型的信息和存储在对象中数据的类型。

将序列化对象写入文件之后,可以从文件中读取出来,并且对它进行反序列化,也就是说,对象的类型信息、对象的数据,还有对象中的数据类型可以用来在内存中新建对象。

整个过程都是Java虚拟机(JVM)独立的,也就是说,在一个平台上序列化的对象可以在另一个完全不同的平台上反序列化该对象。

类ObjectInputStream 和ObjectOutputStream是高层次的数据流,它们包含序列化和反序列化对象的方法。

ObjectOutputStream 类包含很多写方法来写各种数据类型,但是一个特别的方法例外:

public final void writeObject(Object x) throws IOException

上面的方法序列化一个对象,并将它发送到输出流。相似的ObjectInputStream 类包含如下反序列化一个对象的方法:

public final Object readObject() throws IOException, 
                                 ClassNotFoundException

该方法从流中取出下一个对象,并将对象反序列化。它的返回值为Object,因此,你需要将它转换成合适的数据类型。

为了演示序列化在Java中是怎样工作的,我将使用之前教程中提到的Employee类,假设我们定义了如下的Employee类,该类实现了Serializable 接口。

public class Employee implements java.io.Serializable {
   public String name;
   public String address;
   public transient int SSN;
   public int number;
   public void mailCheck() {
      System.out.println("Mailing a check to " + name
                           + " " + address);
   }
}

请注意,一个类的对象要想序列化成功,必须满足两个条件:

该类必须实现 java.io.Serializable 对象。

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

如果你想知道一个Java标准类是否是可序列化的,请查看该类的文档。检验一个类的实例是否能序列化十分简单, 只需要查看该类有没有实现java.io.Serializable接口。


序列化对象

ObjectOutputStream 类用来序列化一个对象,如下的SerializeDemo例子实例化了一个Employee对象,并将该对象序列化到一个文件中。

该程序执行后,就创建了一个名为employee.ser文件。该程序没有任何输出,但是你可以通过代码研读来理解程序的作用。

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

import java.io.*;

public class SerializeDemo {
   public static void main(String [] args) {
      Employee e = new Employee();
      e.name = "Reyan Ali";
      e.address = "Phokka Kuan, Ambehta Peer";
      e.SSN = 11122333;
      e.number = 101;
      try
      {
         FileOutputStream fileOut =
         new FileOutputStream("/tmp/employee.ser");
         ObjectOutputStream out = new ObjectOutputStream(fileOut);
         out.writeObject(e);
         out.close();
         fileOut.close();
         System.out.printf("Serialized data is saved in /tmp/employee.ser");
      }catch(IOException i)
      {
          i.printStackTrace();
      }
   }
}

反序列化对象

下面的DeserializeDemo程序实例了反序列化,/tmp/employee.ser存储了Employee对象。

import java.io.*;
public class DeserializeDemo {
   public static void main(String [] args) {
      Employee e = null;
      try
      {
         FileInputStream fileIn = new FileInputStream("/tmp/employee.ser");
         ObjectInputStream in = new ObjectInputStream(fileIn);
         e = (Employee) in.readObject();
         in.close();
         fileIn.close();
      }catch(IOException i)
      {
         i.printStackTrace();
         return;
      }catch(ClassNotFoundException c)
      {
         System.out.println("Employee class not found");
         c.printStackTrace();
         return;
      }
      System.out.println("Deserialized Employee...");
      System.out.println("Name: " + e.name);
      System.out.println("Address: " + e.address);
      System.out.println("SSN: " + e.SSN);
      System.out.println("Number: " + e.number);
    }
}

以上程序编译运行结果如下所示:

Deserialized Employee...
Name: Reyan Ali
Address:Phokka Kuan, Ambehta Peer
SSN: 0
Number:101

这里要注意以下要点:

readObject() 方法中的try/catch代码块尝试捕获 ClassNotFoundException异常。对于JVM可以反序列化对象,它必须是能够找到字节码的类。如果JVM在反序列化对象的过程中找不到该类,则抛出一个 ClassNotFoundException异常。

注意,readObject()方法的返回值被转化成Employee引用。

当对象被序列化时,属性SSN的值为111222333,但是因为该属性是短暂的,该值没有被发送到输出流。所以反序列化后Employee对象的SSN属性为0。

由JSRUN为你提供的Java在线运行、在线编译工具
        JSRUN提供的Java 在线运行,Java 在线运行工具,基于linux操作系统环境提供线上编译和线上运行,具有运行快速,运行结果与常用开发、生产环境保持一致的特点。