安装
https://github.com/google/protobuf/releases2.配置 protoc 到系统的环境变量中,执行如下命令查看是否安装成功:
$ protoc --version # 如果正常打印 libprotoc 的版本信息就表明 protoc 安装成功
3.安装 ProtoBuf 相关的 golang 依赖库
$ go get -u github.com/golang/protobuf/{protoc-gen-go,proto}使用
1.创建 Demo golang工程
2.在 example 包中编写 person.proto
syntax = "proto3";
package example;
message person { // aa 会生成 Aa 命名的结构体
int32 id = 1;
string name = 2;
}
message all_person { // aa_bb 会生成 AaBb 的驼峰命名的结构体
repeated person Per = 1;
}3.进入 Demo 工程的 example 目录,使用 protoc 编译 person.proto
$ protoc --go_out=. person.proto # 就会生成 person.pb.go 文件
4.在 golang 工程中使用 protobuf 进行序列化与反序列化
# main.go
package main
import (
"github.com/golang/protobuf/proto"
"Demo/example"
"log"
)
func main() {
// 为 AllPerson 填充数据
p1 := example.Person{
Id:*proto.Int32(1),
Name:*proto.String("xieyanke"),
}
p2 := example.Person{
Id:2,
Name:"gopher",
}
all_p := example.AllPerson{
Per:[]*example.Person{&p1, &p2},
}
// 对数据进行序列化
data, err := proto.Marshal(&all_p)
if err != nil {
log.Fatalln("Mashal data error:", err)
}
// 对已经序列化的数据进行反序列化
var target example.AllPerson
err = proto.Unmarshal(data, &target)
if err != nil{
log.Fatalln("UnMashal data error:", err)
}
println(target.Per[0].Name) // 打印第一个 person Name 的值进行反序列化验证
}
优质内容筛选与推荐>>1、2013第四届蓝桥杯C/C++ B组
2、【ECharts,仪表盘样式1】
3、Tensorflow--池化操作
4、添加TLBB模型动画需要对OGRE添加的代码段
5、JavaScript window.location对象