• <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 沛沛 閱讀(674) 評論(0)  編輯 收藏 引用 所屬分類: 開源庫
            日韩精品久久久肉伦网站 | 伊人 久久 精品| 人妻久久久一区二区三区| 久久久久人妻精品一区 | 欧美激情精品久久久久久久| 无码人妻久久一区二区三区免费丨| 国产精久久一区二区三区| 久久精品中文字幕一区| 人人狠狠综合久久亚洲88| 久久人人爽人人爽人人片AV不 | 精品少妇人妻av无码久久| 久久精品国产亚洲AV久 | 久久久精品国产| 久久免费99精品国产自在现线| 久久婷婷五月综合国产尤物app| 精品久久久久久久| 99久久er这里只有精品18| 精品久久久久久无码不卡| 亚洲精品NV久久久久久久久久 | 99久久这里只精品国产免费| 久久91亚洲人成电影网站| 久久AV高潮AV无码AV| 久久久网中文字幕| 久久99精品久久久久久| 久久夜色精品国产欧美乱| 午夜视频久久久久一区| 怡红院日本一道日本久久| 老色鬼久久亚洲AV综合| 性做久久久久久久久老女人| 国产69精品久久久久9999| 国产成人综合久久综合| 国产69精品久久久久9999APGF | 久久精品久久久久观看99水蜜桃| 国内精品久久久久久久亚洲| 欧美亚洲另类久久综合婷婷| 国产精品嫩草影院久久| 狠色狠色狠狠色综合久久| 久久国产免费观看精品3| 少妇精品久久久一区二区三区| 久久久久久久波多野结衣高潮| 伊人 久久 精品|