java - 克里奥 vs jackson

标签 java json serialization jackson kryo

我正在检查 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 毫秒???

最佳答案

尝试使用 kryo.readObject(arg0, arg1) 而不是 kryo.readClassAndObject(input); 它可以更有效地序列化 Java 中的对象。

关于java - 克里奥 vs jackson ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25973062/

相关文章:

java - 在 Java 中存储数据的最佳方式是什么? (数组与数组列表)

javascript - 通过 JSON.stringify 解析 map

android - 将位图上传到 Ruby Rails 服务器

c# - 使用 JObject 修改集合中的 JSON 字段

java - 从 PHP 到 Java。有什么建议吗?

javascript - WebView SpeedTest 结果始终低于 CustomTab 或 Chrome

java - 使用旋转矩阵的旋转角度如何对应度数

php - 根据另一个表或字段中的数组中的记录保存 id

c# - 我在反序列化期间遇到异常

serialization - XNA和XBox的F#二进制序列化