48
30 我有一个X类型的对象,我想在将其发送到S3之前将其转换为字节数组。有人可以告诉我该怎么做吗?我感谢您的帮助。
你要执行的操作称为“ 序列化 ”。有几种方法可以做到,但是如果你不需要花哨的东西,我认为使用标准Java对象序列化就可以了。
也许你可以使用类似的东西?
package com.example; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.io.ObjectInputStream; import java.io.ObjectOutputStream; public class Serializer { public static byte[] serialize(Object obj) throws IOException { try(ByteArrayOutputStream b = new ByteArrayOutputStream()){ try(ObjectOutputStream o = new ObjectOutputStream(b)){ o.writeObject(obj); } return b.toByteArray(); } } public static Object deserialize(byte[] bytes) throws IOException, ClassNotFoundException { try(ByteArrayInputStream b = new ByteArrayInputStream(bytes)){ try(ObjectInputStream o = new ObjectInputStream(b)){ return o.readObject(); } } } }
可以对此进行一些改进。至少事实是每个字节数组只能读取/写入一个对象,这可能是你想要的,也可能不是。
请注意,“只有支持该java.io.Serializable接口的对象才能写入流”(请参阅参考资料java.io.ObjectOutputStream)。
java.io.Serializable
java.io.ObjectOutputStream
由于你可能会碰到它,因此,持续分配和调整大小java.io.ByteArrayOutputStream可能会成为瓶颈。根据你的线程模型,你可能需要考虑重用某些对象。
java.io.ByteArrayOutputStream
对于未实现Serializable接口的对象的序列化,你可能需要编写自己的序列化器,例如,使用的read * / write *方法java.io.DataOutputStream和get * / put *方法(java.nio.ByteBuffer可能与反射一起使用),或者引入第三方依赖性。
read * / write *
java.io.DataOutputStream
get * / put *
java.nio.ByteBuffer
该站点提供了一些序列化框架的列表和性能比较。查看API,看来Kryo可能适合你的需求。