使用嵌套HashMap和自定义类进行Kryo序列化

时间:2015-01-26 19:23:42

标签: java serialization kryo

我正在尝试使用kryo序列化一个自定义类,该类本身包含一些自定义对象,更具体地说是自定义对象的HashMap。我想知道处理这样的事情的正确方法。下面是我尝试序列化的类(Data),嵌套的类以及我当前的kryo实现。这是正确的方法吗?

public class Data {
    int id,
    int name,
    ItemList items;
}

public Class ItemList {

    HashMap<String, Item> items;
}

public Class Item {

    String itemId;
    String itemName;
    String itemDesc;
}

kryo.register(Data.class, new Serializer<Data>() {
    public void write (Kryo kryo, Output output, Data object) {
        output.writeInt(object.id);
        output.writeInt(object.name);
        kryo.writeClassAndObject(output, items);
    }

    public Tile read (Kryo kryo, Input input, Class<Data> type) {
        Data data = new Data();
        kryo.reference(data);
        data.id = input.readInt();
        data.name = input.readString();
        data.items = kryo.readClassAndObject(input);
        return data;
    }
});

1 个答案:

答案 0 :(得分:1)

您可以使用MapSerializer类。像:

MapSerializer serializer = new MapSerializer();
kryo.register(HashMap.class, serializer);
kryo.register(LinkedHashMap.class, serializer);
serializer.setKeyClass(String.class, kryo.getSerializer(String.class));
serializer.setKeysCanBeNull(false);
serializer.setKeyClass(String.class, kryo.getSerializer(String.class));

更多,你可以到这里http://kryo.googlecode.com/svn-history/r416/trunk/test/com/esotericsoftware/kryo/MapSerializerTest.java