golang 使用 protobuf 的教程

99封情书 提交于 2020-07-28 15:06:03

原文链接: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找相应的镜像),这个包大约长这个样子。很多教程上面都没有提到这个包,导致编译出来的程序并不能运行

4、创建一个test.proto文件

//指定版本

//注意proto3与proto2的写法有些不同

syntax = "proto3";



//包名,通过protoc生成时go文件时

package test;



//手机类型

//枚举类型第一个字段必须为0

enum 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

会生成一个test.pb.go的文件,具体的文件内容我就不截图了。

 

6、在go语言中使用protobuf

package main

import (
	"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()
}

 

 

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!