protobuf标准消息方法

简介: protobuf标准消息方法 1.标准消息方法 每个消息类包含一些其他方法允许你检查和控制整个消息,包括: · IsInitialized() :检查是否所有必须(required)字段都已经被赋值了。

protobuf标准消息方法

1.标准消息方法

每个消息类包含一些其他方法允许你检查和控制整个消息,包括:

· IsInitialized() :检查是否所有必须(required)字段都已经被赋值了。

· __str__() :返回人类可读的消息表示,便于调试。

· CopyFrom(other_msg) :使用另外一个消息的值来覆盖本消息。

· Clear() :清除所有元素的值,回到初识状态。

2.解析与串行化

最后,每个ProtocolBuffer类有些方法用于读写消息的二进制数据。包括:

· SerializeToString() :串行化,并返回字符串。注意是二进制格式而非文本。

· ParseFromString(data) :解析数据。

他们是成对使用的,提供二进制数据的串行化和解析。

3.ProtocolBuffer与面向对象设计

ProtocolBuffer类只是用于存取数据的,类似于C++中的结构体,他们并没有在面向对象方面做很好的设计。如果你想要给这些类添加更多的行为,最好的方法是包装(wrap)。包装同样适合于复用别人写好的 .proto 文件。这种情况下,你可以把ProtocolBuffer生成类包装的很适合于你的应用,并隐藏一些数据和方法,暴露有用的函数等等。 你不可以通过继承来给自动生成的类添加行为这会破坏他们的内部工作机制。

原文

https://developers.google.com/protocol-buffers/docs/reference/python/google.protobuf.message.Message-class?hl=zh-CN

https://developers.google.com/protocol-buffers/docs/encoding?hl=zh-CN

http://www.cnblogs.com/foxhengxing/archive/2010/08/10/1796165.html

http://blog.csdn.net/caisini_vc/article/details/5599468

http://blog.csdn.net/ciml/article/details/5753367

目录
相关文章
|
编解码 Java 编译器
【Protobuf】Protobuf中的Message语法规范
在Message中定义一个或者多个字段,FieldType是字段的数据类型,可以是基本类型(如int32、string、bool等)或其他定义的Message类型。fieldName是字段的名称,可以根据需求自定义。fieldNumber是字段的唯一标识号,用于在消息的二进制编码中标识字段。
369 0
|
3月前
|
存储 分布式计算 Java
|
3月前
|
XML 存储 JSON
(十二)探索高性能通信与RPC框架基石:Json、ProtoBuf、Hessian序列化详解
如今这个分布式风靡的时代,网络通信技术,是每位技术人员必须掌握的技能,因为无论是哪种分布式技术,都离不开心跳、选举、节点感知、数据同步……等机制,而究其根本,这些技术的本质都是网络间的数据交互。正因如此,想要构建一个高性能的分布式组件/系统,不得不思考一个问题:怎么才能让数据传输的速度更快?
|
6月前
gRPC三种流和消息格式(一)
gRPC三种流和消息格式
229 0
|
6月前
|
C++
[序列化协议] --- protobuf
[序列化协议] --- protobuf
63 0
|
6月前
|
存储 XML JSON
protobuf原理以及实例(Varint编码)
protobuf原理以及实例(Varint编码)
145 0
|
6月前
|
存储 Java Go
|
6月前
gRPC三种流和消息格式(二)
gRPC三种流和消息格式
90 0
|
消息中间件 Dubbo Java
Simple RPC - 02 通用高性能序列化和反序列化设计与实现
Simple RPC - 02 通用高性能序列化和反序列化设计与实现
64 2
|
C++ 容器
使用protobuf的简单流程记录、编译protobuf时遇到的坑 以及 链接protobuf的坑
使用protobuf的简单流程记录、编译protobuf时遇到的坑 以及 链接protobuf的坑
316 0