我个人将尝试避免Java的“内置”序列化:
- 它不能移植到其他平台
- 效率不高
- 它非常脆弱-使它能够处理一个类的多个版本有些棘手。除非您小心,否则即使更改编译器也可能破坏序列化。
有关实际字节的含义的详细信息,请参见Java Object Serialization
Specification。
有多种选择,例如:
- 正如您所展示的,XML和JSON(当然有各种XML风格)
- YAML
- Facebook的Thrift(RPC以及序列化)
- Google协议缓冲区
- 黑森州(网络服务以及序列化)
- 阿帕奇(Apache Avro)
- 您自己的自定义格式
(免责声明:我在Google工作,并且正在将协议缓冲区移植到C#作为我20%的项目,因此很明显,我认为这是一种很好的技术:)
出于明显的原因,跨平台格式几乎总是比特定于平台的格式更具限制性-例如,协议缓冲区具有一组有限的本机类型-
但互操作性非常有用。您还需要考虑版本控制的影响,以及向后和向前的兼容性等。文本格式通常是可以手动编辑的,但是在空间和时间上效率较低。
基本上,您需要仔细查看您的需求。



