golang 使用 protobuf 的教程

原文链接:https://www.cnblogs.com/jkko123/p/7161843.html
1、下载protobuf的编译器protoc
地址:https://github.com/google/protobuf/releases
window:
下载: protoc-3.3.0-win32.zip
解压,把bin目录下的protoc.exe复制到GOPATH/bin下,GOPATH/bin加入环境变量。
当然也可放在其他目录,需加入环境变量,能让系统找到protoc.exe
linux:
下载:protoc-3.3.0-linux-x86_64.zip 或 protoc-3.3.0-linux-x86_32.zip
解压,把bin目录下的protoc复制到GOPATH/bin下,GOPATH/bin加入环境变量。
如果喜欢编译安装的,也可下载源码自行安装,最后将可执行文件加入环境变量。

2、获取protobuf的编译器插件protoc-gen-go
进入GOPATH目录
运行

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

如果成功,会在GOPATH/bin下生成protoc-gen-go.exe文件
3、获取protobuf的运行库google.golang.org/protobuf(可以在github找相应的镜像),这个包大约长这个样子。很多教程上面都没有提到这个包,导致编译出来的程序并不能运行
golang 使用 protobuf 的教程
文章图片

4、创建一个test.proto文件
//指定版本//注意proto3与proto2的写法有些不同syntax = "proto3"; //包名,通过protoc生成时go文件时package test; //手机类型//枚举类型第一个字段必须为0enum PhoneType {HOME = 0; WORK = 1; }//手机message Phone {PhoneType type = 1; string number = 2; }//人message Person {//后面的数字表示标识号int32 id = 1; string name = 2; //repeated表示可重复//可以有多个手机repeated Phone phones = 3; }//联系簿message ContactBook {repeated Person persons = 1; }

5、运行如下命令
protoc --go_out=. *.proto

【golang 使用 protobuf 的教程】会生成一个test.pb.go的文件,具体的文件内容我就不截图了。

6、在go语言中使用protobuf
package mainimport ( "fmt" "github.com/golang/protobuf/proto" "io/ioutil" "os" test "test" )func write() { p1 := &test.Person{ Id:1, Name: "小张", Phones: []*test.Phone{ {Type:test.PhoneType_HOME, Number:"111111111"}, {Type:test.PhoneType_WORK, Number:"222222222"}, }, } p2 := &test.Person{ Id:2, Name: "小王", Phones: []*test.Phone{ {Type:test.PhoneType_HOME, Number:"333333333"}, {Type:test.PhoneType_WORK, Number:"444444444"}, }, } //创建地址簿 book := &test.ContactBook{} book.Persons = append(book.Persons, p1) book.Persons = append(book.Persons, p2) //编码数据 data, _ := proto.Marshal(book) //把数据写入文件 ioutil.WriteFile("./test.txt", data, os.ModePerm) }func read() { //读取文件数据 data, _ := ioutil.ReadFile("./test.txt") book := &test.ContactBook{} //解码数据 proto.Unmarshal(data, book) for _, v := range book.Persons { fmt.Println(v.Id, v.Name) for _, vv := range v.Phones { fmt.Println(vv.Type, vv.Number) } } }func main() { write() read() }

golang 使用 protobuf 的教程
文章图片



    推荐阅读