• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            每天早晨叫醒你的不是鬧鐘,而是夢想

              C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
              62 Posts :: 0 Stories :: 5 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(1)

            我參與的團隊

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

             轉載自:Protocol Buffers Language Guide之proto文件類型格式分析[關鍵點翻譯] | 漂泊如風
            1、 
            定義一個消息類型:

            message SearchRequest {

            required string query = 1;

            optional int32 page_number = 2;

            optional int32 result_per_page = 3;

            }

            A.特定域的類型:兩個整型變量page_number和result_per_page、一個string類型的變量query。也可以定義為其他類型如:枚舉和其它message類型。

            B. 指派一個標簽:這個標簽是唯一的,它的范圍可以使1~229-1,當然19000~19999是不可以使用的,因為protocol buffer內部使用。其中1~15保留為經常使用的消息元素。

            C. 指定字段規則:指定的消息字段的規則有以下幾種:a.required 一個結構良好的message必須有一個這樣的字段。b.optional 結構良好的message有零個或者一個這樣的字段。c.repeated 這個字段可以重復任意多次(包括零次)。說明:在repeated后面加上[packed = true]可以取得更高效的編碼。如:repeated int32 samples = 4 [package=true];

            D.可以在一個文件中添加多個message,在編譯生成cpp代碼后,將對應多個類。

            E. Proto注釋的添加和cpp一樣,用雙斜杠即可。

            F. 運行protocol buffer 編譯器按照指定的選項生成特定語言的代碼,在生成的代碼中包含了對proto文件中聲明的變量的設定、取得、序列化消息到輸出流和從輸入流中分解出你的消息的操作。詳細可以參考對應語言的protocol buffer API。

            2、 標量值類型

            標量消息字段有表中以下幾種(對應項為自動生成的類中的類型):

            .proto Type Notes C++ Type Java Type
            double double double
            float float float
            int32 Uses variable-length encoding. Inefficient for encoding negative numbers – if your field is likely to have negative values, use sint32 instead. int32 int
            int64 Uses variable-length encoding. Inefficient for encoding negative numbers – if your field is likely to have negative values, use sint64 instead. int64 long
            uint32 Uses variable-length encoding. uint32 int[1]
            uint64 使用變長編碼 uint64 long[1]
            sint32 Uses variable-length encoding. Signed int value. These more efficiently encode negative numbers than regular int32s. int32 int
            sint64 Uses variable-length encoding. Signed int value. These more efficiently encode negative numbers than regular int64s. int64 long
            fixed32 Always four bytes. More efficient than uint32 if values are often greater than 228. uint32 int[1]
            fixed64 Always eight bytes. More efficient than uint64 if values are often greater than 256. uint64 long[1]
            sfixed32 Always four bytes. int32 int
            sfixed64 Always eight bytes. int64 long
            bool bool boolean
            string A string must always contain UTF-8 encoded or 7-bit ASCII text. string String
            bytes May contain any arbitrary sequence of bytes. string ByteString

            3、 Optional字段的默認值

            設定方法如:optional int32 result_per_page = 3 [default = 10];

            如果沒有指定則:string默認值為空串,bool為false,數字類型的為零,枚舉類型的默認值為枚舉定義列表中的第一個值。

            4、 枚舉

            message SearchRequest {
              required string query = 1;
              optional int32 page_number = 2;
              optional int32 result_per_page = 3 [default = 10];
              enum Corpus {
                UNIVERSAL = 0;
                WEB = 1;
                IMAGES = 2;
                LOCAL = 3;
                NEWS = 4;
                PRODUCTS = 5;
                VIDEO = 6;
              }
              optional Corpus corpus = 4 [default = UNIVERSAL];
            }

            外部message可以通過MessageType.EnumType取得其中的值

            5、 使用其他的message類型

            message也可以作為一個類型進行使用,例如:

            message SearchResponse {

            repeated Result result = 1;

            }

            message Result {

            required string url = 1;

            optional string title = 2;

            repeated string snippets = 3;

            }

            當然一個message可以在不同的文件中進行定義,使用的時候可以使用import進行加入:import “myproject/other_protos.proto”;

            6、 嵌套類型

            message SearchResponse {

            message Result {

            required string url = 1;

            optional string title = 2;

            repeated string snippets = 3;

            }

            repeated Result result = 1;

            }

            上面例子中,result在SearchResponse中進行定義,如果希望在外部的message中調用result,你可以使用:Parent.Type:

            message SomeOtherMessage {

            optional SearchResponse.Result result = 1;

            }

            當然了也可以嵌套一個消息任意深度:

            message Outer {                  // Level 0
              message MiddleAA {  // Level 1
                message Inner {   // Level 2
                  required int64 ival = 1;
                  optional bool  booly = 2;
                }
              }
              message MiddleBB = {  // Level 1
                message Inner = {   // Level 2
                  required int32 ival = 1;
                  optional bool  booly = 2;
                }
              }
            }

            分組:在創建一個新的message類型時,這種特點一般不被贊成使用,往往用嵌套的message類型代替。

            message SearchResponse {

            repeated group Result = 1 {

            required string url = 2;

            optional string title = 3;

            repeated string snippets = 4;

            }

            }

            只是用了大括號進行括起來,注意標點!這個和上面的那個例子是一致的。

            7、 更新一個消息類型

            一個已經存在的message類型不再滿足你的需要,在不改變以前定義的格式的基礎上進行更新。遵照如下規則:

            A、 不要改變已經存在字段的數字標簽。

            B、 任何你添加的新字段應該是optional或者repeated類型。

            C、 非必須字段可以被刪除,同時標簽數字在你更新的message類型中不再被使用。(更好的方法是為字段更名,可以加上OBSOLETE_前綴,這樣將來使用你的proto文件的用戶就不能意外的使用這個數字了)

            D、一個非必須的字段可以轉變為一個擴展,反過來也一樣,同時類型和數字保持不變。

            E、 int32、uint32、int64、uint64和bool都是兼容的。

            F、 sint32和sint64是兼容的,但是并不與其他整型數兼容。

            G、string和bytes相互兼容。

            H、 嵌入message和bytes兼容

            I、 fixed32和sfixed32,fixed64和sfixed64兼容

            8、 擴展

            舉例:

            message Foo {
              // ...
              extensions 100 to 199;
            }

            字段數字[100, 199]保留用以擴展,其他用戶可以再Foo中使用這些標記數字添加新的字段,如下:

            extend Foo {

            optional int32 bar = 126;

            }

            這樣就在Foo中添加了類型為int32的新字段bar,在編譯生成的文件中訪問擴展字段的方法稍有不同:

            Foo foo;

            foo.SetExtension(bar, 15);

            其他的處理方法有HasExtension(),ClearExtension(),GetExtension(),MutableExtension(), andAddExtension().

            說明:擴展字段可以是任何字段類型,包括message類型。

            擴展的嵌套:

            message Baz {

            extend Foo {

            optional int32 bar = 126;

            }

            }

            C++訪問擴展的方法:

            Foo foo;

            foo.SetExtension(Baz::bar, 15);

            唯一不同的就是在bar前面加了個Baz,就這么簡單。

            提倡不是用嵌套的擴展。

            擴展標簽數字的選擇:

            message Foo {

            extensions 1000 to max;

            }

            max= 229 – 1, 或者 536,870,911.但是不包含19000~19999,具體原因參照上文。

            9、 

            舉例:

            package foo.bar;

            message Open { … }

            在另外一個message中使用這個包的方法:

            message Foo {

            required foo.bar.Open open = 1;

            }

            生成的C++代碼中package被聲明為命名空間。Open將在命名空間foo::bar中。

            10、 服務的定義

            舉例如下:

            service SearchService {

            rpc Search (SearchRequest) returns (SearchResponse);

            }

            11、 選項

            。。。

            12、 產生你的類

            下載源碼,配置并編譯源碼生成編譯器。編譯參數:

            protoc –proto_path=IMPORT_PATH –cpp_out=DST_DIR –java_out=DST_DIR –python_out=DST_DIR path/to/file.proto

            說明:

            a. LMPORT_PATH是指定你的.proto文件坐在的目錄。

            b. 提供以下輸出:

            –cpp_out在DST_DIR產生C++代碼

            –java_out在DST_DIR產生Java代碼

            –python_out在DST_DIR產生python代碼

            c. 必須提供一個或者多個.proto文件作為輸入。當然多個.proto文件可以同時被指定編譯。

            posted on 2011-04-05 18:29 沛沛 閱讀(679) 評論(0)  編輯 收藏 引用 所屬分類: 開源庫
            久久精品国产亚洲AV麻豆网站| 国产日韩久久久精品影院首页 | 94久久国产乱子伦精品免费| 少妇高潮惨叫久久久久久| 丁香色欲久久久久久综合网| 色偷偷偷久久伊人大杳蕉| 国产成人精品免费久久久久| 国产日韩久久免费影院| 99久久香蕉国产线看观香| 波多野结衣中文字幕久久| 成人精品一区二区久久| 伊人久久大香线蕉综合网站| 久久婷婷五月综合97色直播| 国产精品久久久久久福利漫画 | 欧美亚洲国产精品久久| 久久丫精品国产亚洲av| 久久国产精品视频| 无码人妻精品一区二区三区久久久| 久久综合欧美成人| 久久久久久久免费视频| 精品久久久久久国产| 区久久AAA片69亚洲 | 欧美精品九九99久久在观看| 久久国产精品99久久久久久老狼| 久久久久18| 久久se精品一区精品二区| 精品久久久一二三区| 精品久久久久久无码免费| 久久精品中文字幕无码绿巨人| 一本久久综合亚洲鲁鲁五月天| 91麻豆精品国产91久久久久久| 亚洲精品国产美女久久久| 国内精品久久久久久久久电影网| 久久久久亚洲av毛片大| 久久精品国产72国产精福利| 国产精品美女久久久久网| 久久久精品人妻一区二区三区蜜桃| 伊人情人综合成人久久网小说| 久久久99精品成人片中文字幕| 香港aa三级久久三级| 99久久国产综合精品五月天喷水 |