Go使用protobuf
Posted garvenc
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Go使用protobuf相关的知识,希望对你有一定的参考价值。
本文更新于2019-01-03。
- 从https://github.com/protocolbuffers/protobuf/releases下载protoc(如:Windows则下载protoc-3.6.1-win32.zip)。protoc命令位于bin目录下。
- go get github.com/golang/protobuf。
- 编译github.com/golang/protobuf/protoc-gen-go。因protoc需调用protoc-gen-go,故需将protoc-gen-go放在环境变量PATH指定的目录中,或protoc所在的目录。
定义proto文件。如:
syntax = "proto2"; package example; enum FOO { X = 17; }; message Test { required string label = 1; optional int32 type = 2 [default=77]; repeated int64 reps = 3; }
使用protoc生成go代码,生成的文件名为*.pb.go。
protoc --proto_path=IMPORT_PATH --go_out=DST_DIR *.proto
- --proto_path:同-I,指定proto文件的目录,缺省则为当前进程目录。
- --go_out:指定go文件生成目录。
调用(示例中假设生成的go代码位于path/to/example)。
package main import ( "log" "github.com/golang/protobuf/proto" "path/to/example" ) func main() { test := &example.Test{ Label: proto.String("hello"), Type: proto.Int32(17), Reps: []int64{1, 2, 3}, } 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()) } // etc. }
以上是关于Go使用protobuf的主要内容,如果未能解决你的问题,请参考以下文章
ProtoBuf 生成 Go 代码去掉 JSON tag omitempty
Go语言 go get 找不到 google.golang.org/protobuf/encoding/prototext 解决办法