ProtoBuf lite版中使用Any

版本3.13.0
因为google/protobuf/any.proto,不带option optimize_for = LITE_RUNTIME;且没有编译到lite版中,所以我们自己实现一个any

syntax = "proto3";

option optimize_for = LITE_RUNTIME;


message VdiAny {
  
  string type_url = 1;

  bytes value = 2;
}

原样拷贝过来加上option optimize_for = LITE_RUNTIME;

生成对应的message类,在生成的类中加上packFrom和unPackTo

  template <typename T, class = typename std::enable_if<std::is_convertible<T, const ::PROTOBUF_NAMESPACE_ID::MessageLite&>::value>::type>
  void PackFrom(const T& message) {
    _any_metadata_.PackFrom<T>(message);
  }

  template <typename T, class = typename std::enable_if<std::is_convertible<T, const ::PROTOBUF_NAMESPACE_ID::MessageLite&>::value>::type>
  void PackFrom(const T& message,
    const std::string& type_url_prefix) {
    _any_metadata_.PackFrom<T>(message, type_url_prefix);
  }

  template <typename T, class = typename std::enable_if<std::is_convertible<T, const ::PROTOBUF_NAMESPACE_ID::MessageLite&>::value>::type>
  bool UnpackTo(T* message) const {
    return _any_metadata_.UnpackTo<T>(message);
  }

//添加一个成员变量
::PROTOBUF_NAMESPACE_ID::internal::AnyMetadata _any_metadata_;

//构造函数中添加成员变量的初始化
VdiAny::VdiAny(::PROTOBUF_NAMESPACE_ID::Arena* arena)
  : ::PROTOBUF_NAMESPACE_ID::MessageLite(arena) ,
  _any_metadata_(&type_url_, &value_) {    //调用成员变量的构造函数
  SharedCtor();
  RegisterArenaDtor(arena);
  // @@protoc_insertion_point(arena_constructor:VdiAny)
}

demo

syntax = "proto3";

//import "google/protobuf/any.proto";

import "vdiAny.proto";

option optimize_for = LITE_RUNTIME;
 
 
message Apply_data
{
    uint32 apply_data_id = 1;
    uint64 apply_time = 2;
}
 
message Apply_list
{
    uint32 apply_list_id = 1;
}
 
message Test
{
    int32                   id = 1;
    VdiAny     				data = 2;
}
  Test test;

  Apply_data data;
  data.set_apply_data_id(111);
  Apply_list list;
  list.set_apply_list_id(222);

  //设置any数据
  ZTSLOG(INFO, "set apply_data data:");
  test.mutable_data()->PackFrom(data);


if (test.data().Is<Apply_data>()) {
    //解析
    if (test.data().UnpackTo(&data1)) {
	  ZTSLOG(INFO, data1.apply_data_id());
	  ZTSLOG(INFO, "unpackTo data success");
    }
    else {
	  ZTSLOG(INFO, "unpackTo data error");
    }
  }
  else {
	ZTSLOG(INFO, "is not apply_data");
  }
在Python中使用protobuf的Any类型,你需要先定义和编译两个.proto文件,并使用protoc命令生成对应的Python代码。你可以使用以下命令来编译这两个.proto文件: protoc --python_out=. TransportMessage.proto protoc --python_out=. WeChatOnlineNoticeMessage.proto 接下来,你可以在Python代码中使用protobuf的Any类型。通过在.proto文件中定义Any字段,并使用pack和unpack函数来序列化和反序列化任意类型的数据。 在序列化时,你可以使用pack函数将数据打包成Any类型。例如,假设你有一个message对象msg,你可以使用以下代码将其打包成Any类型的数据: any_message = Any() any_message.Pack(msg) 在反序列化时,你可以使用unpack函数将Any类型的数据解包成原始类型。例如,假设你有一个Any类型的数据any_message,你可以使用以下代码将其解包成原始类型: msg = Message() any_message.Unpack(msg) 注意,解包前需要先创建一个空的Message对象,用于存储解包后的数据。 需要注意的是,使用Any类型需要在.proto文件中引入google.protobuf.Any和google.protobuf.AnyOptions。你可以在.proto文件中添加以下内容: import "google/protobuf/any.proto"; import "google/protobuf/any_options.proto"; 这样就可以在.proto文件中使用Any类型了。 总结起来,要在Python中使用protobuf的Any类型,你需要: 1. 定义和编译.proto文件,生成对应的Python代码; 2. 在.proto文件中引入google.protobuf.Any和google.protobuf.AnyOptions; 3. 在代码中使用pack和unpack函数来序列化和反序列化任意类型的数据。 你可以根据以上步骤来使用protobuf的Any类型。希望对你有所帮助!如果你还有其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值