zoukankan      html  css  js  c++  java
  • 序列化与反序列化

    使用ObjectInputStream和ObjectOutPutStream读写类必须实现serializable接口,将实现了该接口的对象转换为一个字节序列,并在以后可以将这个字节序列恢复成原来的对象。

    什么时候需要使用序列化?

    1、内存中的对象需要写入硬盘  2、用套接字在网络上传输对象  3、RMI传输对象

    序列化:

    FileOutPutStream fout = new FileOutPutStream(".../.../文件名");//  也可以使用ByteArrayOutputStream

    ObjectOutputStream out = new ObjectOutputStream(fout);

    out.writeObject(要序列化的对象名);

    out.close();

    反序列化:

    FileInputStrean fin = new FileInputStream(".../.../文件名");//  也可以使用ByteArrayInputStream

    ObjectInputStream in = new ObjectInputStream(fin);

    s  = (Student)in.readObject();

    in.close();

    在反序列化是会检查当前对象与之前对象的SerialVersionUID是否一致,如果不一致则会抛出InvalidCastException(序列化版本不一致)的错误。

    一般通过增加一个默认值得方法来避免兼容性错误:

    private static final long SerialVersionUID = 1L;

    注:对象中的transient、static 类型的变量不会写入。

  • 相关阅读:
    react-webpack-express
    React总结和遇到的坑
    vue+node+mongodb实现的功能
    webpack整体了解
    webpack踩坑
    深入了解MongoDB
    实现pdf word在线浏览和下载
    node实现爬虫
    火客声音分析
    抖音二婷衣橱分析
  • 原文地址:https://www.cnblogs.com/siv8/p/5944275.html
Copyright © 2011-2022 走看看