【问题标题】:Serialize C++ classes between processes and across the network在进程之间和跨网络序列化 C++ 类
【发布时间】:2021-07-23 07:46:51
【问题描述】:

我想了解如何在进程之间或跨网络传输 C++ 类的内容。

我正在阅读 Google Protobuf 教程:

https://developers.google.com/protocol-buffers/docs/cpptutorial

看来您必须创建一个抽象的非 C++ 接口来表示您的类:

syntax = "proto2";

package tutorial;

message Person {
  optional string name = 1;
  optional int32 id = 2;
  optional string email = 3;

  enum PhoneType {
    MOBILE = 0;
    HOME = 1;
    WORK = 2;
  }
}

但是,我更愿意通过 C++ 代码(而不是抽象)指定我的类,然后添加类似 serialize()deserialize() 的方法。

Google Protobuf 可以做到这一点吗?或者这就是 Protobuf 的工作方式,我需要使用不同的序列化技术?

更新

这样做的原因是我不想维护两个接口。我宁愿拥有一个 C++ 类,更新它,而不必担心第二个.proto 接口/定义。代码可维护性。

【问题讨论】:

  • 我曾经将它与我的手写 C++ 类结合使用过一次,尽管我可以将我的类中的内容复制到从 .proto 定义生成的类中。

标签: c++ serialization deserialization protocol-buffers


【解决方案1】:

这就是 Protobuf 的工作原理。如果要序列化手动编写的 C++ 类,则必须使用其他东西。但是,我不确定您真的想要这样,因为您将不得不将自己限制在没有不变量的非常简单的字段中(就像在 Protobuf 中一样)或自己编写自定义(反)序列化逻辑.

【讨论】:

  • 但肯定在一天结束时,即使是复合类最终仍会分解为原始类型?也许有指针和字符串,我确定这是由库处理的?
  • @user997112 cpp 不一定是代码优先反射代码的理想环境; Java 和 .NET 中存在执行您想做的事情的工具,但在 cpp 中?不太确定
  • @user997112 肯定会的。您可以尝试查看 Boost::Serialization 库,但 C++ 中没有反射,因此您将不得不求助于某种预处理/代码生成,或者手动编写一些列出您的字段的代码。
【解决方案2】:

您可以制作一个简单的协议缓冲区来保存二进制信息,但这有点打破了使用协议缓冲区的意义。

您可以通过使用 SerializeToString() 和 ParseFromString() 将二进制信息简单地序列化为字符串来欺骗系统。

还有 SerializeToOstream() 和 ParseFromIstream()。

协议缓冲区的真正价值在于能够在使用单一定义的同时跨程序、系统和语言使用消息。如果您不使用他们定义的协议发送消息;这比简单地使用本机 C++ 功能需要更多的工作。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2018-08-16
    • 2011-08-03
    • 2019-05-30
    • 2018-11-19
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多