いるProtobufデータフォーマットは、効率的な、プラットフォームに依存し、言語に依存しない、スケーラブルであり、連続したデータストレージシステムRPCシステムのために使用することができます。
いるProtobuf
はじめにいるProtobuf
Protobuf
されProtocol Buffer
、それは2008年にGoogle Inc.の独立した短いです、高効率、オープンソースのプラットフォーム、言語に依存しない、スケーラブルなデータ形式として現在いるProtobufインタフェース記述言語の仕様では、ゴー言語RPCインターフェイスツールのための基礎として使用することができます。
いるProtobuf使用
protobuf
データプロトコルは、言語に依存しているので、我々はその後、シリアライズとデシリアライズのプロセスデータを達成するために、コードの言語を指定するために特殊な工具を用いて生成されたIDLファイルを記述する必要があります。
開発プロセスは、実質的に次のようにコード2. 1. IDL 3.シリアライゼーションおよびデシリアライゼーションを生成した指定された言語の調製
いるProtobuf文法
コンパイラのインストール
ptotoc
protobuf
C ++コンパイラが中に書かれているとの契約は、自分自身によると、オペレーティングシステムの対応バージョンをダウンロードしてくださいprotoc
:コンパイラhttps://github.com/protocolbuffers/protobuf/releases解凍がにコピーした後、GOPATH/bin
ディレクトリ。
protoc-GEN-行きます
インストールツールは、コード言語を生成行きます
go get -u github.com/golang/protobuf/protoc-gen-go
IDLで書かれたコード
protobuf_demo/address
呼ばれる新しい1つのディレクトリperson.proto
以下のようにファイルの内容です:
// 指定使用protobuf版本
// 此处使用v3版本
syntax = "proto3";
// 包名,通过protoc生成go文件
package address;// 性别类型
// 枚举类型第一个字段必须为0
enum GenderType {
SECRET = 0;
FEMALE = 1;
MALE = 2;
}// 人
message Person {
int64 id = 1;
string name = 2;
GenderType gender = 3;
string number = 4;
}// 联系簿
message ContactBook {
repeated Person persons = 1;
}
```生成go语言代码
在
protobuf_demo/address
目录下执行以下命令。address $ protoc --go_out=. ./person.proto
此时在当前目录下会生成一个
person.pb.go
文件,我们的Go语言代码里就是使用这个文件。 在protobuf_demo/main.go
文件中:package main import ( "fmt" "io/ioutil" "github.com/golang/protobuf/proto" "github.com/Q1mi/studygo/code_demo/protobuf_demo/address" ) // protobuf demo func main() { var cb address.ContactBook p1 := address.Person{ Name: "小王子", Gender: address.GenderType_MALE, Number: "7878778", } fmt.Println(p1) cb.Persons = append(cb.Persons, &p1) // 序列化 data, err := proto.Marshal(&p1) if err != nil { fmt.Printf("marshal failed,err:%v\n", err) return } ioutil.WriteFile("./proto.dat", data, 0644) data2, err := ioutil.ReadFile("./proto.dat") if err != nil { fmt.Printf("read file failed, err:%v\n", err) return } var p2 address.Person proto.Unmarshal(data2, &p2) fmt.Println(p2) }