您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

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

在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.DataOutputStreamget * / put *方法java.nio.ByteBuffer可能与反射一起使用),或者引入第三方依赖性。

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

java 2022/1/1 18:22:24 有576人围观

撰写回答


你尚未登录,登录后可以

和开发者交流问题的细节

关注并接收问题和回答的更新提醒

参与内容的编辑和改进,让解决方法与时俱进

请先登录

推荐问题


联系我
置顶