生产企业网站欣赏,东营建设信息网站电话,怎么用自己的网站做邮箱,怎样批量做全国网站您要执行的操作称为“序列化”。 有几种方法可以做到#xff0c;但是如果您不需要花哨的东西#xff0c;我认为使用标准Java对象序列化就可以了。也许您可以使用这样的东西#xff1f;package com.example;import java.io.ByteArrayInputStream;import java.io.ByteArrayOut…您要执行的操作称为“序列化”。 有几种方法可以做到但是如果您不需要花哨的东西我认为使用标准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.nio.ByteBuffer)。由于可能会遇到问题因此java.nio.ByteBuffer的不断分配和调整大小可能会成为瓶颈。 根据您的线程模型您可能需要考虑重用某些对象。对于未实现java.nio.ByteBuffer接口的对象的序列化您可能需要编写自己的序列化程序例如使用java.nio.ByteBuffer的read * / write *方法和java.nio.ByteBuffer的get * / put *方法可能还要加上反射或者拉入 第三方依赖性。该站点提供了一些序列化框架的列表和性能比较。 查看API看来Kryo可能适合您的需求。