1. 程式人生 > >golang 使用 protobuf 的教程

golang 使用 protobuf 的教程

編譯安裝 win32 pen per protobuf mage Go語言 marshal port

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、創建一個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;
}

4、運行如下命令

> protoc --go_out=. *.proto

會生成一個test.pb.go的文件,具體的文件內容我就不截圖了。

5、在go語言中使用protobuf

package main;

import (
	"github.com/golang/protobuf/proto"
	"protobuf/test"
	"io/ioutil"
	"os"
	"fmt"
)

func write() {
	p1 := &test.Person{
		Id:   1,
		Name: "小張",
		Phones: []*test.Phone{
			{test.PhoneType_HOME, "111111111"},
			{test.PhoneType_WORK, "222222222"},
		},
	};
	p2 := &test.Person{
		Id:   2,
		Name: "小王",
		Phones: []*test.Phone{
			{test.PhoneType_HOME, "333333333"},
			{test.PhoneType_WORK, "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 的教程