java - 使用 Kryo(自定义序列化程序)序列化对象

标签 java serialization kryo

我有一个包含对象数组的对象。我愿意

  • A) 将这个对象数组存储在同一个文件中

  • B) 对这些对象使用自定义序列化。

例如,我有一个 Map 对象,其中包含 Tile[][] 数组。我可以很好地处理 Ints,但对如何处理对象感到困惑:

    kryo.register(Map.class, new SimpleSerializer<Map>() {
        public void write(ByteBuffer buffer, Map map) {

            buffer.putInt(map.getId());
            System.out.println("Putting: " + map.getId());


        }

        public Map read(ByteBuffer buffer) {
            int id = buffer.getInt();
            System.out.println("Getting: " + id);

            Map map = new Map(id, null, 0, 0, 0, 0);

            return (map);
        }
    });

最佳答案

从你的例子中我可以看出你正在使用 Kryo v1。我建议使用 Kryo v2。

您可以像您一样为 Map 设置序列化器,然后序列化每个键和值。要序列化每个对象,请使用输出类写入数据并使用输入类读取数据,或者调用 Kryo 实例上的方法以使其处理对象。

使用内置的 MapSerializer 会更容易。您只需要自定义 Tile 对象的序列化。您可以让它们扩展 KryoSerialized,也可以注册一个序列化器。这是一个例子...

public class Tile implements KryoSerializable {
    int x, y;
    Object something;

    public void write (Kryo kryo, Output output) {
        output.writeInt(x);
        output.writeInt(y);
        kryo.writeClassAndObject(output, something);
    }

    public void read (Kryo kryo, Input input) {
        x = input.readInt();
        y = input.readInt();
        something = kryo.readClassAndObject(input);
    }
}

这是另一个示例,使用 Serializer 而不是 KryoSerialized:

public class Tile {
    int x, y;
    Object something;
}

kryo.register(Tile.class, new Serializer<Tile>() {
    public void write (Kryo kryo, Output output, Tile object) {
        output.writeInt(object.x);
        output.writeInt(object.y);
        kryo.writeClassAndObject(output, object.something);
    }

    public Tile read (Kryo kryo, Input input, Class<Tile> type) {
        Tile tile = new Tile();
        kryo.reference(tile); // Only necessary if Kryo#setReferences is true AND Tile#something could reference this tile.
        tile.x = input.readInt();
        tile.y = input.readInt();
        tile.something = kryo.readClassAndObject(input);
        return tile;
    }
});

这在 read 方法中稍微复杂一些,因为在使用 Kryo 实例反序列化子对象之前调用了 Kryo#reference。如果根本不使用引用,或者如果您知道“某物”对象不可能引用我们刚刚创建的图 block ,则可以省略此操作。如果您仅使用 Input 读取数据,则无需调用 Kryo#reference。

关于java - 使用 Kryo(自定义序列化程序)序列化对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7909572/

相关文章:

java - 如何编写数字+字符串的验证?

java - 当开发工具重新启动 Web 服务器时,计划任务不会停止

PHP:反序列化已序列化并插入到 Mysql 数据库中的数据并回显到 PHP 中的表

apache-spark - 为什么kryo注册在SparkSession中不起作用?

java - 如何获取java变量的更新值?

java - instant.truncatedTo(ChronoUnit.HOURS) 返回大于原始值的值

serialization - 使用 Doctrine MongoDB ODM 进行文档序列化

c# - 可移植类库 : recommended replacement for [Serializable]

java - Kryo 崩溃 EnvironmentFailureException

scala - 如何在spark中使用kryo序列化器注册StringType$