主頁 > 知識庫 > 在go語言中安裝與使用protobuf的方法詳解

在go語言中安裝與使用protobuf的方法詳解

熱門標(biāo)簽:汕頭小型外呼系統(tǒng) 釘釘有地圖標(biāo)注功能嗎 黃岡人工智能電銷機(jī)器人哪個好 濱州自動電銷機(jī)器人排名 惠州電銷防封電話卡 浙江高頻外呼系統(tǒng)多少錢一個月 阿里云ai電話機(jī)器人 鄭州亮點(diǎn)科技用的什么外呼系統(tǒng) 建造者2地圖標(biāo)注

簡介

本文主要給大家介紹了關(guān)于go語言安裝使用protobuf的相關(guān)內(nèi)容,分享出來供大家參考學(xué)習(xí),下面話不多說了,來一起看看詳細(xì)的介紹吧。

protobuf是Google開發(fā)出來的一個語言無關(guān)、平臺無關(guān)的數(shù)據(jù)序列化工具,在rpc或tcp通信等很多場景都可以使用。通俗來講,如果客戶端和服務(wù)端使用的是不同的語言,那么在服務(wù)端定義一個數(shù)據(jù)結(jié)構(gòu),通過protobuf轉(zhuǎn)化為字節(jié)流,再傳送到客戶端解碼,就可以得到對應(yīng)的數(shù)據(jù)結(jié)構(gòu)。這就是protobuf神奇的地方。并且,它的通信效率極高,“一條消息數(shù)據(jù),用protobuf序列化后的大小是json的10分之一,xml格式的20分之一,是二進(jìn)制序列化的10分之一”。

安裝

編譯安裝protobuf的編譯器protoc

  wget https://github.com/google/protobuf/releases/download/v2.6.1/protobuf-2.6.1.tar.gz
  tar zxvf protobuf-2.6.1.tar.gz
  cd protobuf-2.6.1./configure
  make
  make install

        執(zhí)行 protoc  -h 查看安裝是否成功

安裝插件 protoc-gen-go,它是一個go程序,編譯它之后將可執(zhí)行文件執(zhí)行路徑寫入環(huán)境變量

go get github.com/golang/protobuf/protoc-gen-go

獲取proto包

go get github.com/golang/protobuf/proto

在go中使用

protobuf的使用方法是將數(shù)據(jù)結(jié)構(gòu)寫入到.proto文件中,使用protoc編譯器編譯(間接使用了插件)得到一個新的go包,里面包含go中可以使用的數(shù)據(jù)結(jié)構(gòu)和一些輔助方法。

編寫test.proto文件

 package example;
 
 enum FOO { X = 17; };
 
 message Test {
  required string label = 1;
  optional int32 type = 2 [default=77];
  repeated int64 reps = 3;
  optional group OptionalGroup = 4 {
  required string RequiredField = 5;
  }
 }

    編譯:

    執(zhí)行 protoc --go_out=. *.proto 生成 test.pb.go 文件

    將test.pb.go文件放入example文件夾(對應(yīng)上面package)中,作為example包

try

 package main

 import (
  "log"

  "github.com/golang/protobuf/proto"
  "example"
 )

 func main() {
  test := example.Test {
   Label: proto.String("hello"),
   Type: proto.Int32(17),
   Reps: []int64{1, 2, 3},
   Optionalgroup: example.Test_OptionalGroup {
    RequiredField: proto.String("good bye"),
   },
  }
  data, err := proto.Marshal(test)
  if err != nil {
   log.Fatal("marshaling error: ", err)
  }
  newTest := example.Test{}
  err = proto.Unmarshal(data, newTest)
  if err != nil {
   log.Fatal("unmarshaling error: ", err)
  }
  // Now test and newTest contain the same data.
  if test.GetLabel() != newTest.GetLabel() {
   log.Fatalf("data mismatch %q != %q", test.GetLabel(), newTest.GetLabel())
  }
  //test.GetOptionalgroup().GetRequiredField()
  //etc
 }

一些對應(yīng)關(guān)系

  • message Test對為 struct 結(jié)構(gòu),其屬性字段有了對應(yīng)的get方法,在go中可以使用test.GetLabel() 、test.GetType()獲取test對象的屬性
  • OptionalGroup對應(yīng)為 struct中的內(nèi)嵌struct
  • proto文件中repeated屬性對于slice結(jié)構(gòu)
  • test.Reset()可以使其所有屬性置為0值
  • 使用Marshal和Unmarshal可以輕松的編碼和解碼

這些只是一些特性,想要仔細(xì)研究可以查看github上的wiki:https://github.com/golang/protobuf

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • 詳解vue中使用protobuf踩坑記
  • vue中使用protobuf的過程記錄
  • Android中使用protobuf的具體示例
  • C#使用Protocol Buffer(ProtoBuf)進(jìn)行Unity中的Socket通信
  • Protobuf的簡要介紹及使用詳解

標(biāo)簽:瀘州 昭通 泰安 駐馬店 晉中 滄州 東營 阿壩

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《在go語言中安裝與使用protobuf的方法詳解》,本文關(guān)鍵詞  在,語,言中,安裝,與,使用,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《在go語言中安裝與使用protobuf的方法詳解》相關(guān)的同類信息!
  • 本頁收集關(guān)于在go語言中安裝與使用protobuf的方法詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章