windows下go安装并使用protobuf

1. 下载proto windows版本并安装

官方地址:protobuf
解压后复制bin目录下的protoc.exeGOPATH\bib目录中
在这里插入图片描述

2. 安装protoc-gen-go

如果使用go get -u github.com/golang/protobuf/protoc-gen-go 可能会出现如下错误:

go: module github.com/golang/protobuf is deprecated: Use the "google.golang.org/protobuf" module instead.go get: installing executables with 'go get' in module mode is deprecated. Use 'go install pkg@version' instead.For more information, see https://golang.org/doc/go-get-install-deprecation or run 'go help get' or 'go help install'.

使用下面的命令进行下载
go install google.golang.org/protobuf/cmd/protoc-gen-go@latest
安装成功后,在GOPATH\bib目录中可以看到proroc-gen-go.exe

两个全部安装成功后,查看下版本号
在这里插入图片描述

3. proto文件转go文件报错protoc-gen-go: unable to determine go import path for “xxxx.proto”

需要注意的是在proto文件中,记得设置option go_package属性

syntax="proto3"; //版本号
package protobuf;  //包名
option go_package ="./protobuf";

enum ClassName{   //枚举
    class1=0;  //标号 必须从 0开始
    class2=1;
    class3=2;
}

message Student{ //消息,对应于Go的结构体
  string name=1; //1:标号,唯一 即可(相当于数据库中的Id,不一定要从1 ,2的顺序依次排列。)
  int32 age=2;  //必须指定整型的范围,如int32,int64
  string address=3;
  ClassName cn=4;
}
message Students{
   repeated Student person=1;  // repeated 修饰,相当于Go中切片
   string school=2;
}

再使用protoc --go_out=. test.proto命令生成go文件
在这里插入图片描述

在这里插入图片描述

4. 生成的go文件中google.golang.org/protobuf/reflect/protoreflect依赖爆红

import(
protoreflect "google.golang.org/protobuf/reflect/protoreflect"
protoimpl "google.golang.org/protobuf/runtime/protoimpl"
)

GOPATH/src目录下新建google.golang.org文件夹,在该文件下使用命令:
git clone https://e.coding.net/robinqiwei/googleprotobuf.git protobuf

在这里插入图片描述
重新保存生成的xxx.pb.go文件,爆红消失
在这里插入图片描述

5. 基本使用

  • 创建一个.proto文件(用于定义某些需要传输的message格式)
  • 编译proto文件,可以使用protoc --go_out=. *.proto一次性编译当前文件夹下的多个proto文件
  • 编译完成后,protoc编译器将proto文件编译成.pb.go文件
syntax = "proto3"; // 版本信息,不指定会报错
package pb; //生成go文件的包名
option go_package ="./pb"; // 表示在当前文件夹下的pb包中
// message为关键字 用于定义一种消息类型 1234表示打包时字段封装的先后顺序
message Person {
    string name = 1;
    int32 age=2;
    repeated string email = 3; // repeated表示字段允许重复 => 类似于string[]
    repeated PhoneNumber phones = 4;
}


// enum关键字 定义一种枚举类型
enum PhoneType{
    MOBILE=0;
    HOME=1;
    WORK=2;
} 

// message也可以定义一种可以被其他消息嵌套的消息类型
message PhoneNumber{
    string number=1;
    PhoneType type = 2;
}

测试传输

  • 定义与protobuf对应的结构体
  • data, err := proto.Marshal(person 序列化编码得到结构体的二进制文件
  • err = proto.Unmarshal(data, person) 接收到的数据反序列化得到person结构体
    在这里插入图片描述
import (
	"fmt"
	"protobuf_test/pb"

	"google.golang.org/protobuf/proto"
)

func main() {
	person := &pb.Person{
		Name:  "Huzhen",
		Age:   27,
		Email: []string{"24122406@qq.com", "huzhen1145@163.com"},
		Phones: []*pb.PhoneNumber{
			&pb.PhoneNumber{
				Number: "18714859632",
				Type:   pb.PhoneType_MOBILE,
			},
			&pb.PhoneNumber{
				Number: "18714857878",
				Type:   pb.PhoneType_HOME,
			},
			&pb.PhoneNumber{
				Number: "18714854545",
				Type:   pb.PhoneType_WORK,
			},
		},
	}

	fmt.Println("person: ", person)
	// 编码: 将person对象进行序列化,得到二进制文件
	data, err := proto.Marshal(person)
	if err != nil {
		fmt.Println("encode err: ", err)
		return
	}

	fmt.Println("data: ", data)

	// 解码(反序列化)
	person2 := &pb.Person{}
	err = proto.Unmarshal(data, person2)
	if err != nil {
		fmt.Println("decode err: ", err)
		return
	}
	fmt.Println("person2: ", person2)
}

在这里插入图片描述

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

从现在开始壹并超

你的鼓励,我们就是hxd

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值