msgpack:C ++和java之间的消息传递

时间:2012-12-13 09:11:29

标签: java c++ msgpack

我有两个应用程序(一个用C ++编写,另一个用Java编写)。我使用msgpack将C ++类打包为二进制格式。然后我把它发送到Java端。我想知道我是否在java中解压缩此消息(也使用msgpack)我是否获得了正确的Java类对象?

考虑以下示例:

// C++
class Foo
{
public:
    // some methods here...
    void Pack(uint8_t *data, size_t size);
private:
    std::string m1_;
    std::string m2_;
    int m3_;
public:
    MSGPACK_DEFINE(m1_, m2_, m3_);
}

void Foo::Pack(uint8_t *data, size_t size)
{
    msgpack::sbuffer sbuf;
    msgpack::pack(sbuf, *this);

    data = sbuf.data();
    size = sbuf.size();
}

和Java方面:

// Java

public class Foo
{

    public void Unpack(byte[] raw, Foo obj)
    {
        MessagePack msgpack = new MessagePack();
        try
        {
            obj = msgpack.read(raw, Foo.class);
            // Does obj's m1_, m2_ and m3_ contains proper values from C++ class Foo?
        }
        catch(IOException ex)
        {
            // ...
        }
    }

    // ...

    private String m1_;
    private String m2_;
    private int m3_;
}

我不想一个接一个地收拾Foo的成员,因为我有很多。

提前致谢。

1 个答案:

答案 0 :(得分:0)

正如在msgpack网站上所说的

  

MessagePack是一种有效的二进制序列化格式。它允许您在多种语言之间交换数据,如JSON。

所以答案是“是的,你的java对象应该被正确地反序列化”