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

2022-08-31 20:24:23

我有一个X类型的对象,我想在将其发送到S3中存储之前将其转换为字节数组。谁能告诉我怎么做?感谢您的帮助。


答案 1

您要执行的操作称为“序列化”。有几种方法可以做到这一点,但是如果你不需要任何花哨的东西,我认为使用标准的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的连续分配和大小可能会变得非常瓶颈。根据您的线程模型,您可能需要考虑重用某些对象。

对于不实现接口的对象的序列化,您要么需要编写自己的序列化程序,例如使用java.io.DataOutputStream的read*/write*方法和java.nio.ByteBuffer的get*/put*方法,也许与反射一起,或者拉入第三方依赖项。Serializable

此站点具有一些序列化框架的列表和性能比较。看看API,似乎Kryo可能适合你需要的东西。


答案 2

使用和方法从 commons-lang.serializedeserializeSerializationUtils