python Protobuf定義消息類型知識點講解
讓我們從一個非常簡單的例子開始。假設您想要定義“搜索請求”的消息格式。每個請求包含一個查詢字符串、您對查詢結(jié)果感興趣的頁數(shù)以及每頁上有多少個查詢結(jié)果。
可以采用如下的方式來定義消息類型的.proto文件了:
syntax = "proto3"; // 聲明使用 proto3 語法
message SearchRequest {
string query = 1; // 每個字段都要指定數(shù)據(jù)類型
int32 page_number = 2; // 這里的數(shù)字2 是標識符,最小的標識號可以從1開始,最大到2^29 - 1, or 536,870,911。不可以使用其中的[19000-19999]
int32 result_per_page = 3; // 這里是注釋,使用 //
}
(1)第一行指定了你正在使用 proto3 語法:如果不指定,編譯器會使用 proto2。這個指定語法必須是文件的非空非注釋的第一行。
(2)SearchRequest消息格式有三個字段,在消息中承載的數(shù)據(jù)分別對應于每一個字段。其中每個字段都有一個名字和一種類型。
(3)向.proto文件添加注釋,可以使用C/C++/java風格的雙斜杠(//) 語法格式。
(4)在消息體中,每個字段都有唯一的一個數(shù)字標識符。這些標識符用來在消息的二進制格式中識別各個字段,一旦開始使用就不能再改變。
知識點擴展:
Protobuf 不是一個自描述的協(xié)議,序列化后的二進制消息中應該沒有必要的類型信息。所以采取往消息體中增加額外信息的方式來輔助確定消息類型。
- 使用枚舉MsgType定義消息類型,每種消息對應一種消息類型
- 所有的消息都有一個消息類型字段,注意此字段的編號保持確定
- 定義輔助消息BaseMsg,只包含一個消息類型字段,用于輔助反序列化
到此這篇關于python Protobuf定義消息類型知識點講解的文章就介紹到這了,更多相關python Protobuf定義消息類型內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
使用Python將Exception異常錯誤堆棧信息寫入日志文件
這篇文章主要介紹了使用Python將Exception異常錯誤堆棧信息寫入日志文件,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-04-04
Python中.join()和os.path.join()兩個函數(shù)的用法詳解
join()是連接字符串數(shù)組而os.path.join()是將多個路徑組合后返回。接下來通過本文重點給大家介紹Python中.join()和os.path.join()兩個函數(shù)的用法,感興趣的朋友一起看看吧2018-06-06
python?實現(xiàn)?redis?數(shù)據(jù)庫的操作
這篇文章主要介紹了python?包?redis?數(shù)據(jù)庫的操作教程,redis?是一個?Key-Value?數(shù)據(jù)庫,下文基于python的相關資料展開對redis?數(shù)據(jù)庫操作的詳細介紹,需要的小伙伴可以參考一下2022-04-04
淺談python數(shù)據(jù)結(jié)構(gòu)之動態(tài)規(guī)劃
這篇文章主要介紹了淺談python數(shù)據(jù)結(jié)構(gòu)之動態(tài)規(guī)劃,可能很多小伙伴會覺得這個詞很陌生,覺得這是一種很復雜的思想,學習起來很困難,其實并不是這樣,動態(tài)規(guī)劃所講述的知識與動態(tài)與規(guī)劃并無太大關聯(lián),需要的朋友可以參考下2023-07-07

