序列化与反序列化
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)
- 优点:可读
- 缺点:转换速度慢
- 字节
- 优点:转换速度快
- 缺点
- 文本,要被encoded后才可做序列化,因为在计算机内部都是以二进制存储,编码有:uft-8(英文每个字符占1字节,中文每个字符占3个字节), unicode(英文每个字符占2字节,中文每个字符占2个字节);另外还要注意字节顺序;
- ProtoBuf,非语言相关、非平台相关、向下兼容(可扩展字段,不影响旧版本数据);(学习)
以上是关于序列化与反序列化的主要内容,如果未能解决你的问题,请参考以下文章