protobuf c++編程筆記
字段內(nèi)容的定義
//文件名:addressbook.proto
syntax = "proto2";//proto版本
//.proto文件新增一個(gè)可選的package聲明符,用來(lái)防止不同的消息類型有命名沖突。
//包的聲明符會(huì)根據(jù)使用語(yǔ)言的不同影響生成的代碼。對(duì)于C++,產(chǎn)生的類會(huì)被包裝在C++的命名空間中。
package tutorial;package聲明符
message Person {
required string name = 1;//姓名,= 1 二進(jìn)制編碼中使用的唯一 “標(biāo)記”
required int32 id = 2;//ID
optional string email = 3;//email
enum PhoneType {//枚舉消息類型
MOBILE = 0;//proto3版本中,首成員必須為0,成員不應(yīng)有相同的值
HOME = 1;
WORK = 2;
}
//
message PhoneNumber {
required string number = 1;
optional PhoneType type = 2 [default = HOME];
}
repeated PhoneNumber phones = 4;//phones為數(shù)組
}
message AddressBook {
repeated Person people = 1;
}
修飾符
- required 必須提供該字段的值,否則消息會(huì)被認(rèn)為是”未初始化的“
- optional
表示屬性值為可選項(xiàng),不指定使用默認(rèn)值。int和char數(shù)據(jù)類型默認(rèn)為0,string默認(rèn)為空,bool默認(rèn)為false,嵌套message默認(rèn)為構(gòu)造,枚舉為第一個(gè)
- repeated 表示該屬性為重復(fù)字段,可看走是動(dòng)態(tài)數(shù)組,類似于c++中的vector
如果為optional屬性,發(fā)送端沒(méi)有包含該屬性,則接收端在解析式采用默認(rèn)值。對(duì)于默認(rèn)值,如果已設(shè)置默認(rèn)值,則采用默認(rèn)值,如果未設(shè)置,則類型特定的默認(rèn)值為使用,例如string的默認(rèn)值為”“。
字段類型
- package
相當(dāng)于namespace
- message
相當(dāng)于clas
- name
相當(dāng)于屬性值
引用方式
- 類成員函數(shù)變量
package::message.方法()
- 標(biāo)準(zhǔn)meaasge方法
1.bool IsInitialized() const;: 檢查是否已設(shè)置所有必填 required 字段
2.string DebugString() const;: 返回 message 的人類可讀表達(dá),對(duì)調(diào)試特別有用
3.void CopyFrom(const Person& from);用給定的 message 的值覆蓋 message
4.void Clear();: 將所有元素清除回 empty 狀態(tài)
不同字段的方法
1)optional修飾的基本類型:
- set_屬性名(val) :初始化修改屬性值;
- 屬性名():獲取屬性值,只讀模式,返回類型是::google::protobuf::int64;
2)optional修飾的對(duì)象類型:
- 屬性名():返回只讀的屬性類型對(duì)象的引用,屬性類型是指pb中定義的對(duì)象;
- mutable_屬性名():返回可修改的屬性類型對(duì)象的指針,屬性類型是指pb中定義的對(duì)象;
- set_屬性名():初始化設(shè)置字段值
3)repeated修飾的基本類型:
- add_屬性名(val):向?qū)傩约现刑砑釉兀?/li>
- 屬性名_size():獲取集合大??;
- 屬性名(i):返回集合中某一個(gè)元素,返回類型::google::protobuf::int64;
- 屬性名():返回只讀的整個(gè)集合的引用,返回的集合類型是const ::google::protobuf::RepeatedField< ::google::protobuf::int64 >&,可以使用iterator來(lái)迭代遍歷,可用于修改;
- mutable_屬性():返回可修改的整個(gè)集合的指針,返回的集合類型::google::protobuf::RepeatedField< ::google::protobuf::int64 >*,可以使用iterator來(lái)迭代遍歷,可用于修改;
- set_屬性名(int,x):設(shè)置repeated中元素的值
4)repeated修飾的對(duì)象類型:
- add_屬性名():返回可修改的屬性類型對(duì)象的指針(集合中的一個(gè)元素),屬性類型是指pb中定義的對(duì)象;
- 屬性名_size():獲取集合大?。?br />
屬性名(i):返回集合中某一個(gè)元素,返回的是只讀的屬性類型對(duì)象的引用,屬性類型是指pb中定義的對(duì)象;
- mutable_屬性名(i):返回集合中某一個(gè)元素,返回的是可修改的屬性類型對(duì)象的指針,屬性類型是指pb中定義的對(duì)象;
- 屬性名():返回只讀的整個(gè)集合的引用,集合類型是const ::google::protobuf::RepeatedPtrField< pb定義的對(duì)象>& XXX const;,可以使用iterator來(lái)迭代遍歷;
- mutable_屬性名():返回可修改的整個(gè)集合的指針,集合類型是::google::protobuf::RepeatedPtrField< pb定義的對(duì)象>*,可以使用iterator來(lái)迭代遍歷;
序列化
- required字段需要初始化,可以通過(guò)IsInitialized來(lái)檢查是否完成message對(duì)象的初始化
- SerializedAsString(),SerializedToString(std::string* output) 把meaage編碼進(jìn)output
- SerializedToArray(void*,int)把message編碼進(jìn)數(shù)組buff
- SerializedToOstream(ostream*)把message編碼到輸出流
- ByteSize()獲取二進(jìn)制字節(jié)序的大小,可用于初始化存放容器
反序列化
- ParseFromString(std::string& data) 把data解碼到message
- ParseFromArray(char* buf,int size)把buf解碼到message,效率比第一個(gè)快很多
- ParseFromIstream(istream*)從istream輸入流解碼到message
- has_xxx()用于檢查相應(yīng)字段是否存在數(shù)據(jù)
- xxx_size()用于確定repeated字段是否存在,0表示未序列化
總結(jié)
本篇文章就到這里了,希望能給你帶來(lái)幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
函數(shù)外初始化與函數(shù)內(nèi)初始化詳細(xì)解析
函數(shù)內(nèi)初始化:bool FillStr(char *&szDst, int nSize);第一個(gè)參數(shù)中的&一定不能少,這是因?yàn)樵诤瘮?shù)外部我們只聲明了這個(gè)指針,具體這個(gè)指針指向內(nèi)存中的哪個(gè)地址我們并不知道,所以&是為了說(shuō)明傳遞的是這個(gè)指針的引用,那么在函數(shù)內(nèi)初始化后這個(gè)指針的地址也就是外面指針的地址了2013-09-09
OpenCV利用背景建模檢測(cè)運(yùn)動(dòng)物體
這篇文章主要為大家詳細(xì)介紹了OpenCV利用背景建模檢測(cè)運(yùn)動(dòng)物體,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-01-01
Qt實(shí)現(xiàn)獲取基本網(wǎng)絡(luò)信息
這篇文章主要為大家詳細(xì)介紹了Qt實(shí)現(xiàn)獲取基本網(wǎng)絡(luò)信息的相關(guān)知識(shí),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-04-04
基于C++ bitset常用函數(shù)及運(yùn)算符(詳解)
下面小編就為大家?guī)?lái)一篇基于C++ bitset常用函數(shù)及運(yùn)算符(詳解)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-11-11
深入分析Linux下如何對(duì)C語(yǔ)言進(jìn)行編程
本篇文章介紹了,如何在Linux下對(duì)C語(yǔ)言進(jìn)行編程的詳細(xì)概述。需要的朋友參考下2013-05-05
C++中實(shí)現(xiàn)保存數(shù)據(jù)到CSV文件
這篇文章主要介紹了C++中實(shí)現(xiàn)保存數(shù)據(jù)到CSV文件方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08
C/C++實(shí)現(xiàn)手寫數(shù)字識(shí)別的示例詳解
這篇文章主要為大家詳細(xì)介紹了如何使用C/C++實(shí)現(xiàn)手寫數(shù)字識(shí)別,分別處理 32*32 文本數(shù)據(jù)集和mnist 28*28 png數(shù)據(jù)集,感興趣的小伙伴可以跟隨小編一起了解一下2023-10-10

