我正在检查 Java 序列化、Kryo 和 Jackson。
我创建了一些将随机对象序列化 N 次的小代码。我测量序列化和反序列化的时间以及对象的大小。
我对 Kryo 与 Jackson 的大小不太满意,我一直在阅读有关基准的信息,人们在 Kryo 和 Jackson 之间有很大的不同,但是,我在 Kryo 中得到的结果少了大约 5-10%。我不知道我是否遗漏了代码中的某些内容。
这是我给 Kryo 的代码:
public static byte[] writeAsBytes(final Object oObject) {
ByteArrayOutputStream bos = new ByteArrayOutputStream();
Output output = new Output(bos);
kryo2.register(Event.class, 0);
kryo2.writeClassAndObject(output, oObject);
output.close();
return bos.toByteArray();
}
public static <T> T read(final byte[] aObject, final Class<T> clazz) {
T oObject;
ByteArrayInputStream is = new ByteArrayInputStream(aObject);
Input input = new Input(is);
kryo2.register(clazz, 0);
oObject = (T) kryo2.readClassAndObject(input);
input.close();
return oObject;
}
我尝试注册对象并且没有注册,我得到了相同的大小并且时间也相似。
我怎样才能用 Kryo 提高尺寸?我得到的大小和时间:
Size java:5245
Size jackson:5076
Size kryo:4790
14/09/22 12:18:05 INFO util.TimerUtil: DesSerializar Jackson:25135ms,Counter:10001
14/09/22 12:18:05 INFO util.TimerUtil: DesSerializar Java:2637ms,Counter:10001
14/09/22 12:18:05 INFO util.TimerUtil: DesSerializar Kryo:396ms,Counter:10001
14/09/22 12:18:05 INFO util.TimerUtil: Serializar Jackson:985ms,Counter:10001
14/09/22 12:18:05 INFO util.TimerUtil: Serializar Java:1171ms,Counter:10001
14/09/22 12:18:05 INFO util.TimerUtil: Serializar Kryo:397ms,Counter:10001
我执行了很多次代码,我对 Jackson 的反序列化时间感到惊讶,25000 毫秒???