首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Kryo vs Jackson

Kryo vs Jackson
EN

Stack Overflow用户
提问于 2014-09-22 19:30:21
回答 1查看 4K关注 0票数 4

我正在检查Java Serialization,Kryo和Jackson。

我已经创建了一些小代码来序列化随机对象N次。我测量序列化和反序列化的时间以及对象的大小。

我对Kryo和Jackson的尺寸不太满意,我一直在读关于基准的文章,人们在Kryo和Jackson之间有很多不同之处,但是,我只是在Kryo少了5-10%。我不知道我的代码中是否遗漏了什么。

这是我对Kryo的代码:

代码语言:javascript
复制
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改进尺寸呢?我得到的大小和时间:

代码语言:javascript
复制
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的反序列化时间感到惊讶,25000ms?

EN

回答 1

Stack Overflow用户

发布于 2015-08-19 00:08:44

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

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25973062

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档