繁体   English   中英

将类对象转换为字节缓冲区

[英]Converting class objects to byte buffer

我有一个包含两个带有一些变量的类对象的类。 我想通过具有发送功能的USB通过USB发送该类的实例(并在另一端接收)。 send函数接受字节数组(byte [])。

我的问题是如何将类的实例转换为字节数组,以便可以发送它? 我如何在另一端正确地重建它?

下面是我要发送和接收的te类Comsstruct。 欢迎您提出任何建议!

     // ObjectInfo struct definition
public class ObjectInfo {
    int ObjectXCor;
    int ObjectYCor;
    int ObjectMass;
};

// ObjectInfo struct definition
public class SensorDataStruct{
    int PingData;
    int IRData;
    int ForceData;
    int CompassData;
};

// ObjectInfo struct definition
public class CommStruct{
        public ObjectInfo VisionData;
        public SensorDataStruct SensorData;
};

public CommStruct SendPacket;
public CommStruct RecievePacket;

更新

我已经找到了解决方案,但是有了我的建议,我想知道这是否行得通(并且这是否是一个好的解决方案)?

有序列化方法和发送方法:

// Method to convert object to a byte array
public static byte[] serializeObject(CommStruct obj) throws IOException
{
    ByteArrayOutputStream bytesOut = new ByteArrayOutputStream();
    ObjectOutputStream oos = new ObjectOutputStream(bytesOut);
    oos.writeObject(obj);
    oos.flush();
    byte[] bytes = bytesOut.toByteArray();
    bytesOut.close();
    oos.close();
    return bytes;
}

// Send struct function
public void Send(){

    try
{
        // First convert the CommStruct to a byte array
        // Then send the byte array
        server.send(serializeObject(SendPacket));

} 
    catch (IOException e)
{
    Log.e("microbridge", "problem sending TCP message", e);
}   

还有一个接收处理函数:

    public void onReceive(com.example.communicationmodulebase.Client client, byte[] data)
{

    // Event handler for recieving data


    // Try to receive CommStruct 
    try
    {
        ByteArrayInputStream bytesIn = new ByteArrayInputStream(data);
        ObjectInputStream ois = new ObjectInputStream(bytesIn);
        RecievePacket = (CommStruct) ois.readObject();
        ois.close();
    } 
    catch (IOException e)
    {
        Log.e("microbridge", "problem recieving TCP message", e);
    } 
    catch (ClassNotFoundException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
        Log.e("microbridge", "problem recieving TCP message", e);
    }

    // Send the recieved data packet back
    SendPacket = RecievePacket;

    // Send CommStruct
    Send();
}

我的问题是这是否是一个好的解决方案?

您可以让您的类实现Serializable接口 ,然后通过字节流发送该接口 但这是一个非常糟糕的主意,很可能行不通。

之所以无法奏效或不能保证奏效的原因是,不能保证Java的不同实现将使用相同的序列化机制,因此字节数组在不同的Java实现中可能会非常不同。

相反,我建议您将对象转换为xml或json之类的中间格式,然后将其发送。 这样,接收器甚至不必使用Java进行编码。

您可以在这里参考:将对象转换为字节数组,并将字节数组转换为对象http://www.java2s.com/Code/Java/File-Input-Output/Convertobjecttobytearrayandconvertbytearraytoobject.htm

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM