溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何在python項(xiàng)目中使用Protobuf定義消息的類型

發(fā)布時(shí)間:2021-03-03 15:53:18 來源:億速云 閱讀:202 作者:Leah 欄目:開發(fā)技術(shù)

這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)碛嘘P(guān)如何在python項(xiàng)目中使用Protobuf定義消息的類型,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

python是什么意思

Python是一種跨平臺(tái)的、具有解釋性、編譯性、互動(dòng)性和面向?qū)ο蟮哪_本語言,其最初的設(shè)計(jì)是用于編寫自動(dòng)化腳本,隨著版本的不斷更新和新功能的添加,常用于用于開發(fā)獨(dú)立的項(xiàng)目和大型項(xiàng)目。

可以采用如下的方式來定義消息類型的.proto文件了:

syntax = "proto3"; // 聲明使用 proto3 語法
message SearchRequest {
string query = 1; // 每個(gè)字段都要指定數(shù)據(jù)類型
int32 page_number = 2; // 這里的數(shù)字2 是標(biāo)識(shí)符,最小的標(biāo)識(shí)號(hào)可以從1開始,最大到2^29 - 1, or 536,870,911。不可以使用其中的[19000-19999]
int32 result_per_page = 3; // 這里是注釋,使用 //
}

(1)第一行指定了你正在使用 proto3 語法:如果不指定,編譯器會(huì)使用 proto2。這個(gè)指定語法必須是文件的非空非注釋的第一行。

(2)SearchRequest消息格式有三個(gè)字段,在消息中承載的數(shù)據(jù)分別對(duì)應(yīng)于每一個(gè)字段。其中每個(gè)字段都有一個(gè)名字和一種類型。

(3)向.proto文件添加注釋,可以使用C/C++/java風(fēng)格的雙斜杠(//) 語法格式。

(4)在消息體中,每個(gè)字段都有唯一的一個(gè)數(shù)字標(biāo)識(shí)符。這些標(biāo)識(shí)符用來在消息的二進(jìn)制格式中識(shí)別各個(gè)字段,一旦開始使用就不能再改變。

知識(shí)點(diǎn)擴(kuò)展:

Protobuf 不是一個(gè)自描述的協(xié)議,序列化后的二進(jìn)制消息中應(yīng)該沒有必要的類型信息。所以采取往消息體中增加額外信息的方式來輔助確定消息類型。

  1. 使用枚舉MsgType定義消息類型,每種消息對(duì)應(yīng)一種消息類型

  2. 所有的消息都有一個(gè)消息類型字段,注意此字段的編號(hào)保持確定

  3. 定義輔助消息BaseMsg,只包含一個(gè)消息類型字段,用于輔助反序列化

上述就是小編為大家分享的如何在python項(xiàng)目中使用Protobuf定義消息的類型了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI