java kryo 序列化,java – 如何使用Kryo序列化对象并再次反序列化?

Kryo的语法与

java序列化相似.创建kryo对象以及输出/输入,并使用kryos方法之一来执行序列化/反序列化

> kryo.writeClassAndObject(output,object); //如果具体类未知(可以为null)

> kryo.writeObjectOrNull(output,someObject); //如果对象可以为null

> kryo.writeObject(output,someObject); //不能为null,具体类是已知的

每个写入与读取配对

> 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());

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值