栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

在Java中将任何对象转换为字节数组

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

在Java中将任何对象转换为字节数组

你要执行的操作称为“ 序列化 ”。有几种方法可以做到,但是如果你不需要花哨的东西,我认为使用标准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.ByteArrayOutputStream
可能会成为瓶颈。根据你的线程模型,你可能需要考虑重用某些对象。

对于未实现Serializable接口的对象的序列化,你可能需要编写自己的序列化器,例如,使用的

read * / write *
方法
java.io.DataOutputStream
get * / put *
方法(
java.nio.ByteBuffer
可能与反射一起使用),或者引入第三方依赖性。

该站点提供了一些序列化框架的列表和性能比较。查看API,看来Kryo可能适合你的需求。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/441943.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号