我该如何使用Kryo对一个对象进行序列化和反序列化?

6
我该如何使用Kryo对一个对象进行序列化和反序列化呢?我正在使用Kryo 2.23.0版本。
2个回答

7
Kryo的语法与Java序列化非常相似。需要创建一个Kryo对象,以及一个输出/输入对象,使用Kryo方法来执行序列化/反序列化操作。
下面是几个Kryo的方法:
- kryo.writeClassAndObject(output, object); //如果未知具体类(可能为空) - kryo.writeObjectOrNull(output, someObject); //如果对象可以为空 - kryo.writeObject(output, someObject); //对象不能为空且已知具体类
每个写方法都有对应的读方法:
- SomeClass object = (SomeClass)kryo.readClassAndObject(input); - SomeClass someObject = kryo.readObjectOrNull(input, SomeClass.class); - SomeClass someObject = kryo.readObject(input, SomeClass.class);
以下是一个使用writeClassAndObject的示例,将Vector3d序列化到文件中,再进行反序列化。
public class KryoTest {
    public static void main(String[] args){

        Vector3d someObject=new Vector3d(1,2,3);

        //serialise object

        //try-with-resources used to autoclose resources
        try (Output output = new Output(new FileOutputStream("KryoTest.ser"))) {
            Kryo kryo=new Kryo();
            kryo.writeClassAndObject(output, someObject);
        } catch (FileNotFoundException ex) {
            Logger.getLogger(KryTest.class.getName()).log(Level.SEVERE, null, ex);
        }

        //deserialise object

        Vector3d retrievedObject=null;

        try (Input input = new Input( new FileInputStream("KryoTest.ser"))){
            Kryo kryo=new Kryo();
            retrievedObject=(Vector3d)kryo.readClassAndObject(input);
        } catch (FileNotFoundException ex) {
            Logger.getLogger(KryTest.class.getName()).log(Level.SEVERE, null, ex);
        }

        System.out.println("Retrieved from file: " + retrievedObject.toString());
    }
}

所有最新的文档现在已经转移到了Github上;https://github.com/EsotericSoftware/kryo#quickstart


需要注意的是,此示例需要Java 7。 - Mike Rylander

3

一个简单的版本:

Kryo kryo = new Kryo();
// #### Store to disk...
Output output = new Output(new FileOutputStream("file.bin"));
SomeClass someObject = ...
kryo.writeObject(output, someObject);
output.close();
// ### Restore from disk...
Input input = new Input(new FileInputStream("file.bin"));
SomeClass someObject = kryo.readObject(input, SomeClass.class);
input.close();

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接