我最近一直试图学习更多,通常测试Java的序列化的工作和个人项目,我必须说,我知道的越多,我越不喜欢它。这可能是由错误的信息,因此,这就是为什么我问这两件事从你们所有:
1:在字节级别,序列化如何知道如何匹配序列化值与一些类?
我在这里的一个问题是,我做了一个小测试与ArrayList包含值“一”,“两”,“三”。在序列化之后,字节数组占用了78个字节,对于这样低的信息量(19 3 3 4字节),这似乎非常多。授予有一定的开销,但这导致我的第二个问题:
2:序列化可以被认为是一种持久化对象的好方法吗?现在显然,如果我将使用一些自制的XML格式持久性数据将是这样的
One
Two
Three
其中,像XML一般来说,有点blo肿,需要138字节(没有空格,即)。在JSON中也是一样
{
"java.util.ArrayList": {
"elementData": [
"one",
"two",
"three"
]
}
}
这是75字节,因此已经略小于Java的序列化。使用这些基于文本的格式,当然很明显,必须有一种方法来表示您的基本数据,如文本,数字或两者的任何组合。
所以总结一下,序列化在字节/位级别,应该使用什么时候,什么时候不应该使用,序列化真正的好处是什么,除了它标准的Java?