序列化与反序列化

Posted johnnyzhao

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了序列化与反序列化相关的知识,希望对你有一定的参考价值。

  • 什么是序列化

  在计算机科学的数据处理中,是指将数据结据或对象转换成可取用的格式(如存成文件,字节),以让后续在相同或另一台计算机中,能恢复原先状态的过程。

  • 为什么我们需要序列化
    • 存储/传输
    • IPC/RPC
      • IPC,Inter-Process Communication,进程间通信
      • RPC,Remote Procedure Call,远程过程调用
    • 深度copy

 

  • 序列化的类型
    • 文本,要被encoded后才可做序列化,因为在计算机内部都是以二进制存储,编码有:uft-8(英文每个字符占1字节,中文每个字符占3个字节), unicode(英文每个字符占2字节,中文每个字符占2个字节);另外还要注意字节顺序
      • XML, JSON, ProtoBuf(texst)
      • 优点:可读
      • 缺点:转换速度慢
    • 字节
      • 优点:转换速度快
      • 缺点

 

  • ProtoBuf,非语言相关、非平台相关、向下兼容(可扩展字段,不影响旧版本数据);(学习)

以上是关于序列化与反序列化的主要内容,如果未能解决你的问题,请参考以下文章

Java序列化与反序列化

Java序列化与反序列化

java 对象序列化与反序列化

Java序列化与反序列化

Python 序列化与反序列化

[Java安全]Java序列化与反序列化