• Java基础——序列化


    • Java的“对象序列化”能将一个实现了Serialiable接口(标记接口,没有任何方法)的对象转化为一组byte,这样日后要用到这个对象的时候,就能把这些byte数据恢复出来,并据此重新构建那个对象。这一点在跨网络的环境下也是如此,这就意味着序列化机制能自动补偿操作系统方面的差异。也就是说,可以在Windows机器上创建一个对象,序列化之后,再通过网络传到UNIX机器上,最后再那里重建该对象,不用担心在不同平台上数据是怎么表示的,以及byte顺序怎么样,或者 别的什么细节。
    • 要想序列化对象,必须先创建一个OutputStream,然后将其嵌入到ObjectOutputStream,这时就能用writeObject()方法把对象写入OutputStream。读的时候需要把IntputStream嵌入到ObjectIntputStream中,然后调用readObject()方法就可以了。不过,这样读出来的只是一个Object的reference,因此,在用之前,还得先上传。

    详解见:http://www.cnblogs.com/xudong-bupt/archive/2013/05/19/3086493.html

    当两个进程在进行远程通信时,彼此可以发送各种类型的数据。无论是何种类型的数据,都会以二进制序列的形式在网络上传送。发送方需要把这个Java对象转换为字节序列,才能在网络上传送;接收方则需要把字节序列再恢复为Java对象。

      只能将支持 java.io.Serializable 接口的对象写入流中。每个 serializable 对象的类都被编码,编码内容包括类名和类签名、对象的字段值和数组值,以及从初始对象中引用的其他所有对象的闭包

    1.概念

      序列化:把Java对象转换为字节序列的过程。
      反序列化:把字节序列恢复为Java对象的过程。

    2.用途

      对象的序列化主要有两种用途:
      1) 把对象的字节序列永久地保存到硬盘上,通常存放在一个文件中;
      2) 在网络上传送对象的字节序列。

    3.对象序列化

    3.1序列化API

      java.io.ObjectOutputStream代表对象输出流,它的writeObject(Object obj)方法可对参数指定的obj对象进行序列化,把得到的字节序列写到一个目标输出流中。只有实现了Serializable和Externalizable接口的类的对象才能被序列化。

      java.io.ObjectInputStream代表对象输入流,它的readObject()方法从一个源输入流中读取字节序列,再把它们反序列化为一个对象,并将其返回。

    3.2代码示例

     1 import java.io.*;
     2 import java.util.Date;
     3 
     4 public class ObjectSaver {
     5     public static void main(String[] args) throws Exception {
     6         /*其中的  D:\objectFile.obj 表示存放序列化对象的文件*/
     7 
     8         
     9         //序列化对象
    10         ObjectOutputStream out = new ObjectOutputStream(new FileOutputStream("D:\objectFile.obj"));
    11         Customer customer = new Customer("王麻子", 24);    
    12         out.writeObject("你好!");    //写入字面值常量
    13         out.writeObject(new Date());    //写入匿名Date对象
    14         out.writeObject(customer);    //写入customer对象
    15         out.close();
    16 
    17         
    18         //反序列化对象
    19         ObjectInputStream in = new ObjectInputStream(new FileInputStream("D:\objectFile.obj"));
    20         System.out.println("obj1 " + (String) in.readObject());    //读取字面值常量
    21         System.out.println("obj2 " + (Date) in.readObject());    //读取匿名Date对象
    22         Customer obj3 = (Customer) in.readObject();    //读取customer对象
    23         System.out.println("obj3 " + obj3);
    24         in.close();
    25     }
    26 }
    27 
    28 class Customer implements Serializable {
    29     private String name;
    30     private int age;
    31     public Customer(String name, int age) {
    32         this.name = name;
    33         this.age = age;
    34     }
    35 
    36     public String toString() {
    37         return "name=" + name + ", age=" + age;
    38     }
    39 }

    3.3执行结果

    4.说明

      读取对象的顺序与写入时的顺序要一致

      对象的默认序列化机制写入的内容是:对象的类,类签名,以及非瞬态非静态字段的值。

  • 相关阅读:
    docker启动mysql报错||docker ps没有容器,docker ps -a有发现断开了
    Mysql8.x配置安装(附高速下载)以及密码修改
    hibernate配置文件
    笔记,websocket不通,HikariPool Exception during pool initialization,文件下载跨域问题
    微服务中怎么将一个外部的jar添加到项目中
    postman测试需要校验权限的接口的方法
    通过Microsoft SQL Server Managerment Studio数据库管理工具创建SQL Server数据库的链接服务器
    Hashset和Treeset的区别
    maven项目抛出org.springframework.web.util.NestedServletException: Handler dispatch failed; nested exception is java.lang.IncompatibleClassChangeError: Implementing class
    MySQL索引
  • 原文地址:https://www.cnblogs.com/mukekeheart/p/5634986.html
Copyright © 2020-2023  润新知