如何访问 Cap'n'Proto 的序列化数据?

时间:2021-06-23 19:35:14

标签: c++ protocol-buffers capnproto

我正在使用 Cap'n'Proto,我的理解是没有必要进行序列化,因为它已经完成了。所以我的问题是,我将如何访问序列化数据并获取它的大小,以便我可以将它作为字节数组传递给另一个库。

// person.capnp
struct Person {
    name @0 :Text;
    age @1 :Int16;
}

// ...
::capnp::MallocMessageBuilder message;

Person::Builder person = message.initRoot<Person>();
person.setName("me");
person.setAge(20);

// at this point, how do I get some sort of handle to 
// the serialized data of 'person' as well as it's size?

我看过 writePackedMessageToFd(fd, message); 调用,但不太明白传递的是什么,也找不到任何 API 文档。我也没有尝试写入文件描述符,因为我需要以 const void* 形式返回的序列化数据。

查看 Capnproto 的 message.h 文件是这个函数,它位于 MallocMessageBuilder 的基类中,它表示它获取构成消息的原始数据。

kj::ArrayPtr<const kj::ArrayPtr<const word>> getSegmentsForOutput();
// Get the raw data that makes up the message.

但即便如此,我也不知道如何将其设为 const void*

想法?

2 个答案:

答案 0 :(得分:0)

::capnp::MallocMessageBuilder message;

是你的二进制消息,它的大小是

message.sizeInWords()

(以字节为单位的大小除以 8)。

答案 1 :(得分:0)

这似乎是需要的。

// ...
::capnp::MallocMessageBuilder message;

Person::Builder person = message.initRoot<Person>();
person.setName("me");
person.setAge(20);

kj::Array<capnp::word> dataArr = capnp::messageToFlatArray(message);
kj::ArrayPtr<kj::byte> bytes = dataArr.asBytes();

std::string data(bytes.begin(), bytes.end());

const void* dataPtr = data.c_str();

此时,我有一个 const void* dataPtr 和使用 data.size() 的大小。

相关问题