热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

大数据编程入门:Java序列化

在Java中提供了一种对象序列化机制,今天小编将为大家带来大数据编程入门:Java序列化

在Java中提供了一种对象序列化机制,今天小编将为大家带来大数据编程入门: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);

    }

}

运行结果:

这里需要注意以下要点:

readObject()方法中的try/catch代码块尝试捕获ClassnotFoundException异常。对于要反序列化对象的JVM,它必须是能够找到字节码的类。如果JVM在对象反序列化期间找不到该类,则会引发ClassnotFoundException异常。

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

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

以上就是关于大数据编程入门:Java序列化的全部内容了,希望这篇文章可以帮助到大家~

热文荐读:

大数据开发:SpringMVC框架入门

大数据开发:Git工作原理解析

大数据分析:SOA面向服务架构解读

大数据开发:看了都说好的JVM分析



推荐阅读
  • 本文深入探讨了 Java 中的 Serializable 接口,解释了其实现机制、用途及注意事项,帮助开发者更好地理解和使用序列化功能。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • 不确定性|放入_华为机试题 HJ9提取不重复的整数
    不确定性|放入_华为机试题 HJ9提取不重复的整数 ... [详细]
  • 本文介绍了如何使用 Spring Boot DevTools 实现应用程序在开发过程中自动重启。这一特性显著提高了开发效率,特别是在集成开发环境(IDE)中工作时,能够提供快速的反馈循环。默认情况下,DevTools 会监控类路径上的文件变化,并根据需要触发应用重启。 ... [详细]
  • 本文介绍如何使用阿里云的fastjson库解析包含时间戳、IP地址和参数等信息的JSON格式文本,并进行数据处理和保存。 ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • 本文详细介绍了Java中的输入输出(IO)流,包括其基本概念、分类及应用。IO流是用于在程序和外部资源之间传输数据的一套API。根据数据流动的方向,可以分为输入流(从外部流向程序)和输出流(从程序流向外部)。此外,还涵盖了字节流和字符流的区别及其具体实现。 ... [详细]
  • 本文详细探讨了HTML表单中GET和POST请求的区别,包括它们的工作原理、数据传输方式、安全性及适用场景。同时,通过实例展示了如何在Servlet中处理这两种请求。 ... [详细]
  • 在软件开发过程中,MD5加密是一种常见的数据保护手段。本文将详细介绍如何在C#中使用两种不同的方式来实现MD5加密:字符串加密和流加密。 ... [详细]
  • Python自动化处理:从Word文档提取内容并生成带水印的PDF
    本文介绍如何利用Python实现从特定网站下载Word文档,去除水印并添加自定义水印,最终将文档转换为PDF格式。该方法适用于批量处理和自动化需求。 ... [详细]
  • 扫描线三巨头 hdu1928hdu 1255  hdu 1542 [POJ 1151]
    学习链接:http:blog.csdn.netlwt36articledetails48908031学习扫描线主要学习的是一种扫描的思想,后期可以求解很 ... [详细]
  • 本文介绍如何在现有网络中部署基于Linux系统的透明防火墙(网桥模式),以实现灵活的时间段控制、流量限制等功能。通过详细的步骤和配置说明,确保内部网络的安全性和稳定性。 ... [详细]
  • 使用lambda表达式排序Collections.sort(temp,(Stringa,Stringb)-{returnb.compareTo(a);});Collections ... [详细]
  • Nginx 反向代理与负载均衡实验
    本实验旨在通过配置 Nginx 实现反向代理和负载均衡,确保从北京本地代理服务器访问上海的 Web 服务器时,能够依次显示红、黄、绿三种颜色页面以验证负载均衡效果。 ... [详细]
  • 主板IO用W83627THG,用VC如何取得CPU温度,系统温度,CPU风扇转速,VBat的电压. ... [详细]
author-avatar
奇力0_843
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有